【Django开发】0到1美多商城项目md教程第2篇:展示用户注册页面,1. 创建用 ...

打印 上一主题 下一主题

主题 954|帖子 954|积分 2866


美多商城完整教程(附代码资料)主要内容讲述:欢迎来到美多商城!,项目预备。展示用户注册页面,创建用户模块子应用。用户注册业务实现,用户注册前端逻辑。图形验证码,图形验证码接口计划和界说。短信验证码,制止频仍发送短信验证码。账号登录,用户名登录。登录,登录开发文档。用户根本信息,查询并渲染用户根本信息。收货地址,省市区三级联动。收货地址,展示地址前后端逻辑。商品数据库表计划,SPU和SKU。预备商品数据,容器化方案Docker。首页广告,展示首页商品频道分类。商品列表页,列表页面包屑导航。商品搜刮,Haystack扩展建立索引。商品详情页,统计分类商品访问量。购物车管理,添加购物车。购物车管理,删除购物车。订单,结算订单。提交订单,使用乐观锁并发下单。对接系统,订单支付功能。页面静态化,首页广告页面静态化。MySQL读写分离,MySQL主从同步。。部署。meiduo_mallBuild Setup。Summary。

全套笔记资料代码移步: 前往gitee仓库查看

感爱好的小同伴可以自取哦,欢迎大家点赞转发~

全套教程部分目录:



部分文件图片:


展示用户注册页面

创建用户模块子应用

1. 创建用户模块子应用

1.预备apps包,用于管理所有应用

2.在apps包下创建应用users
  1. $ cd ~/projects/meiduo_project/meiduo_mall/meiduo_mall/apps
  2. $ python ../../manage.py startapp users
复制代码

2. 查看项目导包路径

重要提示:

  • 若要知道如何导入users应用并完成注册,需要知道项目导包路径

已知导包路径

  • meiduo_project/meiduo_mall
已知 'users'应用所在目录

  • meiduo_project/meiduo_mall/meiduo_mall/apps/users
得到导入'users'应用的导包路径是:meiduo_mall/apps/users
3. 注册用户模块子应用
  1. INSTALLED_APPS = [
  2.     'django.contrib.admin',
  3.     'django.contrib.auth',
  4.     'django.contrib.contenttypes',
  5.     'django.contrib.sessions',
  6.     'django.contrib.messages',
  7.     'django.contrib.staticfiles',
  8.     'meiduo_mall.apps.users', # 用户模块应用
  9. ]
复制代码
注册完users应用后,运行测试程序。
追加导包路径

思索:

  • 是否可以将注册users应用做的更加简便?
  • 按照如下形式,直接以应用名users注册
  1. INSTALLED_APPS = [
  2.     'django.contrib.admin',
  3.     'django.contrib.auth',
  4.     'django.contrib.contenttypes',
  5.     'django.contrib.sessions',
  6.     'django.contrib.messages',
  7.     'django.contrib.staticfiles',
  8.     'users', # 用户模块应用
  9. ]
复制代码
分析:

  • 已知导包路径

    • meiduo_project/meiduo_mall

  • 已知'users'应用所在目录

    • meiduo_project/meiduo_mall/meiduo_mall/apps/users

  • 若要直接以应用名'users'注册

    • 需要一个导包路径:meiduo_project/meiduo_mall/meiduo_mall/apps

解决办法
  1. * 追加导包路径:`meiduo_project/meiduo_mall/meiduo_mall/apps`
复制代码
1. 追加导包路径

1.查看项目BASE_DIR

2.追加导包路径


2. 重新注册用户模块应用
  1. INSTALLED_APPS = [
  2.     'django.contrib.admin',
  3.     'django.contrib.auth',
  4.     'django.contrib.contenttypes',
  5.     'django.contrib.sessions',
  6.     'django.contrib.messages',
  7.     'django.contrib.staticfiles',
  8.     'users', # 用户模块应用
  9. ]
复制代码
重新注册完users应用后,运行测试程序。
3. 知识要点


  • 查看导包路径

    • 通过查看导包路径,可以快速的知道项目中各个包该如何的导入。
    • 特别是接办老项目时,可以尽快的顺应项目导包的方式。

  • 追加导包路径

    • 通过追加导包路径,可以简化某些目录复杂的导包方式。

展示用户注册页面

1. 预备用户注册模板文件


加载页面静态文件
  1. <head>
  2.     <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
  3.     <title>美多商城-注册</title>
  4.     <link rel="stylesheet" type="text/css" href="{{ static('css/reset.css') }}">
  5.     <link rel="stylesheet" type="text/css" href="{{ static('css/main.css') }}">
  6. </head>
复制代码
2. 界说用户注册视图
  1. class RegisterView(View):
  2.     """用户注册"""
  3.     def get(self, request):
  4.         """
  5.         提供注册界面
  6.         :param request: 请求对象
  7.         :return: 注册界面
  8.         """
  9.         return render(request, 'register.html')
复制代码
3. 界说用户注册路由

1.总路由
  1. urlpatterns = [
  2.     # users
  3.     url(r'^', include('users.urls', namespace='users')),
  4. ]
复制代码
2.子路由
  1. urlpatterns = [
  2.     # 注册
  3.     url(r'^register/$', views.RegisterView.as_view(), name='register'),
  4. ]
复制代码
用户模型类

界说用户模型类

1. Django默认用户认证系统


  • Django自带用户认证系统

    • 它处理用户账号、组、权限以及基于cookie的用户会话。

  • Django认证系统位置

    • django.contrib.auth包罗认证框架的核心和默认的模型。
    • django.contrib.contenttypes是Django内容类型系统,它答应权限与你创建的模型关联。

  • Django认证系统同时处理认证和授权

    • 认证:验证一个用户是否它声称的那个人,可用于账号登录。
    • 授权:授权决定一个通过了认证的用户被答应做什么。

  • Django认证系统包罗的内容

    • 用户:用户模型类、用户认证。
    • 权限:标识一个用户是否可以做一个特定的任务,MIS系统常用到。
    • 组:对多个具有相同权限的用户举行同一管理,MIS系统常用到。
    • 暗码:一个可配置的暗码哈希系统,设置暗码、暗码校验。

2. Django默认用户模型类


  • Django认证系统中提供了用户模型类User保存用户的数据。

    • User对象是认证系统的核心。

  • Django认证系统用户模型类位置

    • django.contrib.auth.models.User


  • 父类AbstractUser介绍

    • User对象根本属性

      • 创建用户(注册用户)必选: username、password
      • 创建用户(注册用户)可选:email、first_name、last_name、last_login、date_joined、is_active 、is_staff、is_superuse
      • 判断用户是否通过认证(是否登录):is_authenticated

    • 创建用户(注册用户)的方法
    1. [/code]
    2. [/list]user = User.objects.create_user(username, email, password, **extra_fields)
    3. [code]* 用户认证(用户登录)的方法
    4. ```python
    5. from django.contrib.auth import authenticate
    6. user = authenticate(username=username, password=password, **kwargs)
    复制代码

    • 处理暗码的方法

      • 设置暗码:set_password(raw_password)
      • 校验暗码:check_password(raw_password)

    3. 自界说用户模型类

    思索:为什么要自界说用户模型类?

    • 观察注册界面会发现,美多商城注册数据中必选用户mobile信息。
    • 但是Django默认用户模型类中没有mobile字段,所以要自界说用户模型类。
    如何自界说用户模型类?

    • 继承自AbstractUser(可通过阅读Django默认用户模型类的源码得知) 。
    • 新增mobile字段。
    1. from django.db import models
    2. from django.contrib.auth.models import AbstractUser
    3.   
    4.   
    5. # Create your models here.
    6.   
    7.   
    8. class User(AbstractUser):
    9.     """自定义用户模型类"""
    10.     mobile = models.CharField(max_length=11, unique=True, verbose_name='手机号')
    11.     class Meta:
    12.         db_table = 'tb_users'
    13.         verbose_name = '用户'
    14.         verbose_name_plural = verbose_name
    15.     def __str__(self):
    16.         return self.username
    复制代码
    4. 知识要点


    • Django自带用户认证系统核心就是User对象,并封装了一系列可用的方法和属性。
    • Django用户认证系统包罗了一系列对用户的操作,比如:模型类,认证,权限,分组,暗码处理等。
    • Django用户认证系统中的用户模型类可以自界说,继承自AbstractUser
    • [Django用户认证系统阐明文档](
    迁移用户模型类

    1. 指定用户模型类

    思索:为什么Django默认用户模型类是User?

    • 阅读源代码:'django.conf.global_settings'
    1. AUTH_USER_MODEL = 'auth.User'
    复制代码
    结论:

    • Django用户模型类是通过全局配置项 AUTH_USER_MODEL 决定的
    配置规则:
    1. AUTH_USER_MODEL = '应用名.模型类名'
    复制代码
    1.   
    2.   
    3. # 指定本项目用户模型类
    4.   
    5.   
    6. AUTH_USER_MODEL = 'users.User'
    复制代码
    2. 迁移用户模型类

    1.创建迁移文件

    • python manage.py makemigrations

    2.执行迁移文件

    • python manage.py migrate

    3. 知识要点


    • 用户认证系统中的用户模型类,是通过全局配置项 AUTH_USER_MODEL 决定的。
    • 如果迁移自界说用户模型类,必须先配置 AUTH_USER_MODEL
    用户注册业务实现

    用户注册业务逻辑分析

    1. 用户注册业务逻辑分析


    用户注册接口计划和界说

    1. 计划接口根本思绪


    • 对于接口的计划,我们要根据具体的业务逻辑,计划出恰当业务逻辑的接口。
    • 计划接口的思绪:

      • 分析要实现的业务逻辑:

        • 明确在这个业务中涉及到几个相关子业务。
        • 将每个子业务当做一个接口来计划。

      • 分析接口的功能任务,明确接口的访问方式与返回数据:

        • 请求方法(如GET、POST、PUT、DELETE等)。
        • 请求地址。
        • 请求参数(如路径参数、查询字符串、表单、JSON等)。
        • 响应数据(如HTML、JSON等)。


    2. 用户注册接口计划

    1.请求方式
    选项方案请求方法POST请求地址/register/2.请求参数:表单参数
    参数名类型是否必传阐明usernamestring是用户名passwordstring是暗码password2string是确认暗码mobilestring是手机号sms_codestring是短信验证码allowstring是是否同意用户协议3.响应结果:HTML

    • register.html
    响应结果响应内容注册失败响应错误提示注册成功重定向到首页3. 用户注册接口界说

    1.注册视图
    1. class RegisterView(View):
    2.     """用户注册"""
    3.     def get(self, request):
    4.         """
    5.         提供注册界面
    6.         :param request: 请求对象
    7.         :return: 注册界面
    8.         """
    9.         return render(request, 'register.html')    def post(self, request):        """        实现用户注册        :param request: 请求对象        :return: 注册结果        """        pass
    复制代码
    2.总路由
    1. urlpatterns = [
    2.     # users
    3.     url(r'^', include('users.urls', namespace='users')),
    4. ]
    复制代码
    3.子路由
    1. urlpatterns = [
    2.     # 注册
    3.     url(r'^register/$', views.RegisterView.as_view(), name='register'),
    4. ]
    复制代码
    未完待续, 同学们请等待下一期

    全套笔记资料代码移步: 前往gitee仓库查看

    感爱好的小同伴可以自取哦,欢迎大家点赞转发~


    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

东湖之滨

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表