八、搭建项目框架
8.1利用Pycharm创建一个新的Django项目Dailyfresh
8.2创建4个app,分别为cart,goods,order,user
8.3创建一个Python Package文件夹,将上述4个app包含进去
8.4最后框架结构如下图:
8.5配置Dailyfresh的settings.py文件:
8.5.1配置路径,代码如下图:
8.5.2配置app,代码如下图:
8.5.3配置模板路径,新建templates文件夹用于存放模板:
8.5.4配置数据库:
8.5.5配置静态文件路径,新建static文件夹存放静态文件:
8.5.6配置Django认证系统使用的模型类,避免发生迁移错误:
8.6配置项目路径,在dailyfresh中的urls.py中设置:
8.6.1在各个app中创建对应的urls.py文件,用于配置app的路径
8.7创建公共模板BaseModel类,先创建db文件夹,在db中创建Base_Model.py文件:
8.7.1将之前写好的Base_Model类导入进Base_Model.py文件中
8.8将之前写好的各个模块的Model类导入各自app的model.py文件中
8.9初始化数据库,在__init.py__文件中设置:
8.10数据库迁移,具体操作指令为:
python manage.py makemigrations
九、用户注册逻辑
9.1将所有静态页面导入static文件夹中
9.2将注册页面导入templates文件夹中,命名为register.html
9.3修改register.html的配置:
9.4利用类视图进行处理,在user/view.py文件中处理:
from django.shortcuts import render,redirect //跳转组件
from django.core.urlresolvers import reverse
from django.core.mail import send_mail
from django.contrib.auth import authenticate, login
from django.views.generic import View //类视图组件
from django.http import HttpResponse
from django.conf import settings
from user.models import User //用户模型类
from celery_tasks.tasks import send_register_active_email //发送邮件的任务函数
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer //实现加密功能
from itsdangerous import SignatureExpired //如果token过期出现的异常
import re //通过正则表达式检查邮箱名是否合法
import time
9.5在user/urls.py文件中配置路由:
from django.conf.urls import url
from user.views import RegisterView, ActiveView, LoginView //注册、用户激活、登录类视图
十、用户激活逻辑
10.1安装itsdangerous:
pip install itsdangerous
10.2利用itsdangerous实现用户信息加密:
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer //导入加密方法并重命名
# 加密用户的身份信息,生成激活token
serializer = Serializer(settings.SECRET_KEY, 3600) //利用django内部的标识符生成token,3600表示一小时后token失效
info = {'confirm':user.id} //需要加密的用户信息
token = serializer.dumps(info) # bytes //加密信息
token = token.decode()
10.3在uesr/view.py中创建一个激活类视图来处理:
10.4在uesr/urls.py中配置对应的路由,如9.5所示:
10.5发送激活邮件:
10.5.1利用163邮箱的smtp服务器帮我们完成发送邮件的操作:
10.5.2在dailyfresh/settings.py中配置邮件:
10.6使用celery实现异步发送邮件:
10.6.1celery介绍: Celery是一个功能完备即插即用的任务队列。它使得我们不需要考虑复杂的问题,使用非常简单。
10.6.2celery的架构:
10.6.3celery在项目中的具体使用:
10.6.3.1在dailyfresh中新建一个celery_task文件夹:
10.6.3.2在tasks.py文件中输入代码:
10.6.3.3回到user/views.py文件中调用任务函数给broker发送任务,如9.4所示:
10.6.3.4启动Wroker,它会从broker中提取任务进行执行:
十一、用户登录流程
11.1将静态页面login.html导入模板中,修改资源路径:
11.2在login.html中修改表单属性和显示错误信息:
11.3配置redis作为Django缓存和session存储后端
11.3.1安装django-redis包
11.3.2配置django缓存和session,在dailyfresh/settings.py中配置:
11.4设计用户登录逻辑,在user/views.py中添加代码: