基于Django的商城开发项目笔记(二)

八、搭建项目框架

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中添加代码:

      

         

猜你喜欢

转载自blog.csdn.net/qq_40652101/article/details/89325935