项目说明
该电商项目类似于京东商城,主要模块有验证,用户,第三方登录,首页广告,商品,购物车,订单,支付以及后台管理系统。项目开发模式采用前后端不分离的模式,为了提高搜索引擎排名,页面整体刷新采用jinja2模板引擎实现,局部刷新采用 vue.js 实现。
项目运行机制如下:
项目搭建
工程创建
项目使用码云进行源码版本控制,在码云创建好后直接克隆到本地即可,然后在项目根目录下执行 virtualenv venv 创建虚拟环境,source venv/bin/activat 激活虚拟环境后,安装 Django 后,执行 django-admin startproject immortal_mall 创建 Django 工程。
配置开发环境
商城项目有两个环境,分别为测试和开发环境,Django项目在创建完成后只有一个 settings配置文件,但是有两个环境需要两个配置文件,这里需要修改django获取配置文件的方式。新建settings包,再新建dev和pro两个配置文件,将默认生成的settings文件里面的内容拷贝到dev和pro文件里
再在mange.py文件里指定开发环境需要的配置文件。
配置jinja2模板引擎
安装jinja2扩展包 pip install jinja2 ,然后在dev文件中配置一下
这里需要注意,如果运行报错了,提示
这是因为注释掉了django默认的模板配置,需要去掉注释。
配置 mysql 数据库
新建数据库
create database meidou 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': 'root',
'PASSWORD': '12345',
'PORT': '3306'
}
}
Django 默认使用的是 mysqlclient 工具,需要单独安装,这里用pymysql代替,在工程同名子目录的init.py 文件中,写入下面代码。
import pymysql
pymysql.install_as_MySQLdb()
在启动项目时可能会报错:
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 innstall 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_reids.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.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模块自带的TimeRotatingFileHandler,也可以自定义一个handler类去实现。
配置前端静态文件准备静态文件夹 static
指定静态文件加载路径
# 指定加载静态恩建路由前缀
STATIC_URL = '/static/'
# 配置静态文件加载路径
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
最终项目目录: