内容回顾
-
""" 认证模块 校验用户是否存在 保存用户状态 校验用户是否登陆 修改密码 ... 该模块默认需要用到django默认的auth_user表 django的admin后台管理需要用到该表 如何创建超级用户/管理员 python3 manage.py createsuperuser """ from django.contrib import auth
# 1.校验用户名和密码是否正确 auth.authenticate(request,username=username,password=password) """注意括号内用户名和密码必须都给才行,该方法有一个返回值 用户对象/None"""
# 2.保存用户信息 auth.login(request,user_obj) """ 内部自动帮你操作django_session表 request.session[key] = user_obj 该方法执行完毕之后,在任意位置都可以通过request.user获取到当前登陆的用户对象 """
# 3.判断当前用户是否登陆 request.user.is_authenticated()
# 4.校验用户是否登陆装饰器 from django.contrib.auth.decorators import login_required 1.局部配置 @login_required(login_url='/login/') 2.全局配置 LOGIN_URL = '/login/' # 全局省事局部灵活
# 5.验证原密码是否正确 request.user.check_password(old_password)
# 6.修改密码 request.user.set_password(new_password) request.user.save()
# 7.创建用户 from django.contrib.auth.models import User User.objects.create() # 密码不加密 不用 User.objects.create_user() # 普通用户 经常使用 User.objects.create_superuser() # 超级用户(邮箱必填) -
如何扩展auth_user表
# 第一种 利用一对一的表关系 不推荐使用,不太方便 # 第二种 利用面向对象继承 from django.contrib.auth.models import AbstractUser class UserInfo(AbstractUser): # 扩展auth_user表中没有的字段 """ 一定要去配置文件中配置 AUTH_USER_MODEL = '应用名.类名' 1.在没有创建auth_user表的前提下才能替代 如果已经创建了那就换一个库 2.扩展的字段尽量不要与原来的字段冲突 3.之前auth模块所有的功能和方法照样可以使用,知识参考的表由原来的变成了UserInfo """
项目开发流程
1.需求分析
2.项目设计
3.分组开发
4.测试
5.交付上线
-
数据库表设计
-
""" 数据库的表设计是整个项目的重点所在 """
1.用户表 2.个人站点表 3.文章标签表 4.文章分类表 5.文章表 数据库字段优化设计 点赞数 普通字段 点踩数 普通字段 评论数 普通字段 # 只需要确保后续在操作点赞点踩和评论表的时候同步的将对应的普通字段更新即可 6.点赞点踩表 7.评论表 根评论和子评论 to='self' # 7张表之间的关系
今日内容概要
bbs是一个前后端不分离的全栈项目,前端和后端都需要我们自己一步步的完成
-
表创建及同步
-
注册功能
-
forms组件
-
用户头像前端实时展示
-
ajax
-
-
登陆功能
搭建bbs首页
-
自己实现图片验证码
-
ajax
-
-
导航条根据用户是否登陆展示不同的内容
今日内容详细
数据库表创建及同步
"""
由于django自带的sqlite数据库对日期不敏感,所以我们换成MySQL
"""
from django.db import models
# Create your models here.
"""
先写普通字段
之后再写外键字段
"""
from django.contrib.auth.models import AbstractUser
class UserInfo(AbstractUser):
phone = models.BigIntegerField(verbose_name='手机号',null=True)
# 头像
avatar = models.FileField(upload_to='avatar/',default='avatar/default.png',verbose_name='用户头像')
"""
给avatar字段传文件对象 该文件会自动存储到avatar文件下 然后avatar字段只保存文件路径avatar/default.png
"""
create_time = models.DateField(auto_now_add=True)
blog = models.OneToOneField(to='Blog',null=True)
class Blog(models.Model):
site_name = models.CharField(verbose_name='站点名称',max_length=32)
site_title = models.CharField(verbose_name='站点标题',max_length=32)
# 简单模拟 带你认识样式内部原理的操作
site_theme = models.CharField(verbose_name='站点样式',max_length=64) # 存css/js的文件路径
class Category(models.Model):
name = models.CharField(verbose_name='文章分类',max_length=32)
blog = models.ForeignKey(to='Blog',null=True)
class Tag(models.Model):
name = models.CharField(verbose_name='文章标签',max_length=32)
blog = models.ForeignKey(to='Blog', null=True)
class Article(models.Model):
title = models.CharField(verbose_name='文章标题',max_length=64)
desc = models.CharField(verbose_name='文章简介',max_length=255)
# 文章内容有很多 一般情况下都是使用TextField
content = models.TextField(verbose_name='文章内容')
create_time = models.DateField(auto_now_add=True)
# 数据库字段设计优化
up_num = models.BigIntegerField(verbose_name='点赞数',default=0)
down_num = models.BigIntegerField(verbose_name='点踩数',default=0)
comment_num = models.BigIntegerField(verbose_name='评论数',default=0)
# 外键字段
blog = models.ForeignKey(to='Blog', null=True)
category = models.ForeignKey(to='Category',null=True)
tags = models.ManyToManyField(to='Tag',
through='Article2Tag',
through_fields=('article','tag')
)
class Article2Tag(models.Model):
article = models.ForeignKey(to='Article')
tag = models.ForeignKey(to='Tag')
class UpAndDown(models.Model):
user = models.ForeignKey(to='UserInfo')
article = models.ForeignKey(to='Article')
is_up = models.BooleanField() # 传布尔值 存0/1
class Comment(models.Model):
user = models.ForeignKey(to='UserInfo')
article = models.ForeignKey(to='Article')
content = models.CharField(verbose_name='评论内容',max_length=255)
comment_time = models.DateTimeField(verbose_name='评论时间',auto_now_add=True)
# 自关联
parent = models.ForeignKey(to='self',null=True) # 有些评论就是根评论