项目说明

该电商项目类似于京东商城,主要模块有验证、用户、第三方登录、首页广告、商品、购物车、订单、支付以及后台管理系统。

项目开发模式采用前后端不分离的模式,为了提高搜索引擎排名,页面整体刷新采用jinja2模板引擎实现,局部刷新采用vue.js实现。

项目运行机制如下:

file

项目搭建

工程创建

项目使用码云进行源代码版本控制,在码云创建好后直接克隆到本地即可,然后在项目根目录下执行virtualenv venv创建虚拟环境,source venv/bin/activat激活虚拟环境后,安装django后,执行

django-admin startproject immortal_mall创建django工程。

配置开发环境

商城项目有两个环境,分别为测试环境和开发环境,django项目在创建完成后只有一个settings配置文件,但是两个环境需要两个配置文件,这里需要修改django获取配置文件的方式。新建settings包,再新建dev和pro两个配置文件,将默认生成的settings文件里面的内容拷贝至dev和pro文件里,结果如下

file

再在mange.py文件里指定开发环境需要的配置文件,生成环境的后面再说

file

配置jiaja2模板引擎

安装jinja2扩展包pip install jinja2,然后在dev文件中配置一下

file

这里有个注意的点,如果在运行的时候报错了,提示

file

这时是因为注释掉了django默认的模板配置,需要去掉注释,只添加新的版本引起即可。

配置mysql数据库

新建数据库

新建数据库

create database meiduo charset=utf8;

新建mysql用户

create user mall identified by '123456';

授权用户只能访问immortal_mall数据库

grant all on immortal_mall.* to 'mall'@'%';

刷新授权

flush privileges;

配置数据库

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql',

'NAME': 'immortal_mall',

'HOST': '127.0.0.1',

'USER': 'zhouyajun',

'PASSWORD': '12345678',

'PORT': '3306'

}

}

django默认使用的是mysqlclient工具,需要单独安装,这里用pymysql代替,在工程同名子目录的__init__.py文件中,写入下面代码

import pymysql

pymysql.install_as_MySQLdb()

在启动项目对的时候可能会报错,提示mysql

File "/Users/lixiang/.env/lib/python3.6/site-packages/django/db/backends/mysql/base.py", line 36, in raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.version)

django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

具体解决方式可以参考这里https://zhuanlan.zhihu.com/p/76920424

配置redis

商城采用redis作为缓存服务

pip install django-redis

这里是django-redis的使用文档https://django-redis-chs.readthedocs.io/zh_CN/latest/,在dev文件中配置redis

缓存配置

CACHES = {

"default": {

"BACKEND": "django_redis.cache.RedisCache",

"LOCATION": "redis://127.0.0.1:6379/2",

"OPTIONS": {

"CLIENT_CLASS": "django_redis.client.DefaultClient",

}

},

"session": {

"BACKEND": "django_redis.cache.RedisCache",

"LOCATION": "redis://127.0.0.1:6379/3",

"OPTIONS": {

"CLIENT_CLASS": "django_redis.client.DefaultClient",

}

}

}

SESSION_ENGINE = "django.contrib.sessions.backends.cache"

SESSION_CACHE_ALIAS = "session"

default是redis采用的默认配置,用的是2号数据库,session是redis保持保持状态的配置项,用的是3号数据库,

日志配置

日志配置

LOGGING = {

'version': 1,

'disable_existing_loggers': False, # 是否禁用已经存在的日志器

'formatters': { # 日志信息显示的格式

'verbose': {

'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'

},

'simple': {

'format': '%(levelname)s %(module)s %(lineno)d %(message)s'

},

},

'filters': { # 对日志进行过滤

'require_debug_true': { # django在debug模式下才输出日志

'()': 'django.utils.log.RequireDebugTrue',

},

},

'handlers': { # 日志处理方法

'console': { # 向终端中输出日志

'level': 'INFO',

'filters': ['require_debug_true'],

'class': 'logging.StreamHandler',

'formatter': 'simple'

},

'file': { # 向文件中输出日志

'level': 'INFO',

'class': 'logging.handlers.RotatingFileHandler',

'filename': os.path.join(os.path.dirname(BASE_DIR), 'logs/mall.log'), # 日志文件的位置

'maxBytes': 300 * 1024 * 1024,

'backupCount': 10,

'formatter': 'verbose'

},

},

'loggers': { # 日志器

'django': { # 定义了一个名为django的日志器

'handlers': ['console', 'file'], # 可以同时向终端与文件中输出日志

'propagate': True, # 是否继续传递日志信息

'level': 'INFO', # 日志器接收的最低日志级别

},

}

}

这里需要在项目的根目录下手动创建logs文件,写日志的时候呢,我们希望能够自动分日期去写,每天的日志写到不同的文件里,这里可以使用python模块自带的TimedRotatingFileHandler,也可以自定义一个handler类去实现。

我这里呢自己实现了一个类叫做MallRotatingFileHandler

效果如下:

file

该类实现按月划分日志文件,自动按照当天日期命名日志文件,也可以定义文件容量。

配置前端静态文件

准备静态文件夹static

file

指定静态文件加载路径

指定加载静态恩建路由前缀

STATIC_URL = '/static/'

配置静态文件加载路径

STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

运行项目,请求获取一张图片http://127.0.0.1:8989/static/images/adv01.jpg,成功获取表示配置正确。

最终项目各个目录展示成果:

file

欢迎大家去 我的博客 瞅瞅,里面有更多关于测试实战的内容哦!!

python开发商城实战_python框架Django实战商城项目之工程搭建相关推荐

  1. 用python搭建微商城_python框架Django实战商城项目之工程搭建

    项目说明 该电商项目类似于京东商城,主要模块有验证.用户.第三方登录.首页广告.商品.购物车.订单.支付以及后台管理系统. 项目开发模式采用前后端不分离的模式,为了提高搜索引擎排名,页面整体刷新采用j ...

  2. django debug=false后静态文件丢失_python框架Django实战商城项目之工程搭建

    项目说明 该电商项目类似于京东商城,主要模块有验证.用户.第三方登录.首页广告.商品.购物车.订单.支付以及后台管理系统. 项目开发模式采用前后端不分离的模式,为了提高搜索引擎排名,页面整体刷新采用j ...

  3. python开发购物网站_python实现简单购物商城

    本文为大家分享了购物商城小程序,供大家参考,具体内容如下 软件版本:python3.x 功能:实现简单购物商城 1.允许用户选择购买多少件 2.允许多用户登录,下一次登录后,继续按上次的余额继续购买 ...

  4. Python Web前后端分离框架Django+Vue搭建

    Python Web前后端分离框架Django+Vue搭建 对前面所学知识的归纳整理,感兴趣的可以看看,欢迎指正. 一.前后端分离框架介绍 本项目基于 Python 的 Web 框架开发,采用前后端分 ...

  5. python django框架如何导出_python框架django的数据库的正向生成和反向生成

    正向生成,指的是先创建model.py文件,然后通过django内置的编译器,在数据库如mysql中创建出符合model.py的表. 反向生成,指的是先在数据库中create table,然后通过dj ...

  6. python爬虫和定位_Python网络爬虫实战,照片定位与B站弹幕!

    之前两篇已经说完了如何爬取网页以及如何解析其中的数据,那么今天我们就可以开始第一次实战了. Python资源共享群:626017123 这篇实战包含两个内容. * 利用爬虫调用Api来解析照片的拍摄位 ...

  7. python开发工具管理系统_Python开发桌面软件文档及网址管理工具,强迫症的福音...

    原标题:Python开发桌面软件文档及网址管理工具,强迫症的福音 写在前面 这两天用python鼓捣开发了一个软件,分享给同事,觉得很实用,可以大大提高工作效率,想通过平台分享出来给大家 希望给爱好p ...

  8. python 开发视频播放网站_python开发微电影视频网站教程附源码

    做为一个合格的Pythoner,只掌握一个框架是不够,如果你有过其它Python框架(例如django)的使用经验,对比不同框架的特性来学习,你将收获更多 当前信息若含有黄赌毒等违法违规不良内容,请点 ...

  9. python 开发网站过程_Django框架下Python网站开发过程综述

    Django 框架下 Python 网站开发过程综述 韦立梅 1 苏 兵 2 [摘 要] 首先对 D jango . Python 进行简单的介绍,然后从搭建 D jango 的 开发环境.模型的设计 ...

最新文章

  1. sdut AOE网上的关键路径(spfa+前向星)
  2. 德国工业4.0眼里“工业互联网”与“智能制造”
  3. hdu 2063+hdu 1083(最大匹配数)
  4. 怎么证明权重不相同的加权无向图的最小生成树是唯一的 (图论)
  5. mysql 360怎么安装_MySQL安装方法
  6. 浙江师范大学python试卷_2014考研计算机真题试卷及答案(浙江师范大学考点)
  7. vue路由上的#/怎么去掉_如何去掉vue路由中的#
  8. Numpy中数组创建函数的辨析
  9. springboot判断有没有库_Springboot 使用JPA @Query 注解 查询语句条件 有可能为空,Oracle数据库...
  10. ifconfig相关
  11. Android 图片缩略图显示
  12. java归并算法实例_Java编程中实现归并排序算法的实例教程
  13. WebCollector 网页正文快速提取
  14. 手机突然变卡,不得不重置
  15. Web前端的优点有哪些?为什么Web前端可以如此火爆?
  16. 高等数学在计算机领域的应用,计算机专业高等数学应用性改革探索论文
  17. PlaySound使用进阶
  18. 用html做祝福语朋友,朋友关怀祝福语(把祝福语化作露带给你)
  19. nuxt IE语法错误
  20. c/c++中指针学习的两个绝好例子

热门文章

  1. jsp压缩html,使用HtmlCompressor压缩JSP编译的Html代码
  2. Text模式和PDU模式的区别
  3. Exynos4412 内核移植(四)—— MMU 相关知识解析
  4. shell除去重复的行——uniq命令
  5. c#按ESC退出 或者接受其他键盘消息
  6. 使用css优雅解决文字两端对齐的方式之一
  7. react学习(43)----react中将一个元素渲染为 DOM
  8. [vue] 你认为vue的核心是什么?
  9. [css]你有使用过preload、preconnect、prefetch这些属性吗?说说它们都有什么作用?
  10. [css] css中的选择器、属性、属性值区分大小写吗?