一、Form组件
day73 2018-08-10 1. 内容回顾
1. form表单组件
1. 常用字段
1. CharField()
2. ChoiceField()
2. 参数或配置
1. label="label标签显示的文本内容"
2. initial="默认值"
3. widget=forms.widgets.TextInput() --> <input typle='text'/>
widget=forms.widgets.PasswordInput(
attrs={"class": "c1", "s12": "hao"}
)
4. required=False --> is_valid()校验的时候该字段没有值也不报错
5. error_messages={"required": "xx字段不能为空", "max_length": "xx字段最多不能超过位数"}
6. max_length
7. min_length 8. validators=[验证器1,验证器2, ...]
3. 验证器
1. 内置正则验证
from django.core.validators import RegexValidator
validators=[RegexValidator(r'^1[3-9]\d{9}$', "手机号码格式不正确!"), ]
2. 自定义方法实现
from django.core.exceptions import ValidationError
# 自定义校验的方法
def name_check(value):
if '*mei' in value:
raise ValidationError("不符合*核心价值观!")
else:
return value validators=[name_check, ],
4. 钩子函数
0. self.cleaned_data --> 用来存放经过验证数据的大字典
self.add_error("字段名", "错误提示信息") 1. 局部钩子(Hook)
通过自定义一个clean_字段名的方法实现字段的校验
2. 全局钩子
此时 每个字段独立的校验都走完了,cleaned_data中已经存放着所有字段的数据
def clean(self):
print("我可是看过源码的人,我知道你肯定会执行这个方法!")
# 重写父类的clean方法
# 该clean方法, 在每个字段都校验通过之后才调用执行
pwd = self.cleaned_data.get("pwd")
re_pwd = self.cleaned_data.get("re_pwd") if re_pwd and re_pwd == pwd:
# 确认密码和密码相同, 正常
return self.cleaned_data
else:
# 确认密码和密码不同
self.add_error('re_pwd', "两次密码不一致") # ?
raise ValidationError("两次密码不一致") 2. 今日内容
1. auth认证
默认Django内置的认证系统, 默认在数据库中使用auth_user
from django.contrib import auth
1. 创建一个超级用户
python manage.py createsuperuser
2. 验证用户名和密码是否正确
user = auth.authenticate(request, username, password)
3. 登录
auth.login(request, user) --> user是上一步的得到的user对象
4. 注销
auth.logout(request) --> 将当前请求的session数据删除 5. 登录认证的装饰器
auth.decorators.login_required
默认跳转的登录url: /accounts/login/
在settings.py中 配置 LOGIN_URL = "你的登录url" 6. is_authenticated()
判断当前request.user是否经过认证,经过认证就返回True,否则是False 7. AuthenticationMiddleware中间件究竟做了什么?
request.user = user, 匿名用户对象 8. create_user()
9. create_superuser()
10. check_password()
11. set_password() 2. 扩展默认的auth_user表:
from django.contrib.auth.models import AbstractUser
class UserInfo(AbstractUser):
# 扩展auth模块默认的数据表
phone = models.CharField(max_length=11)
注意事项:
1. 告诉Django使用我的UserInfo表来做用户的管理
在settings.py中配置:
AUTH_USER_MODEL = "app名.UserInfo" 3. BBS/CMS
1. 需求分析
1. 登录注册、注销
2. 文章分页
3. 评论
4. 点赞
5. 发帖
6. 查看文章
7. 博客站点主题自定制
8. 博客应该有分类 2. 表结构设计
1. 用户表
2. 文章表
3. 评论 多对一关联文章
4. 点赞/反对 多对一关联文章 一个用户只能对一篇文章点赞一次
5. 博客主题表 存的每个博主的主题css文件
6. 文章分类表 一对多关联文章
7. 文章标签表 多对多关联文章表 每个组 设计一套models.py ,最迟周日的晚上8:00之前发到我QQ邮箱 3. 今日任务
1. 好好玩,调整状态 准备进入项目阶段 4. 周末任务
1. authBlog整理一下
2. 自己在课上注册登录的例子基础上实现一个用户修改密码的功能
1. 登录的用户才能修改密码
2. 修改密码之前先校验原密码是否正确
3. 加上Bootstrao样式
3. 设计BBS项目表结构
4. 复习jQuery和form,周一要用!!!
Django Form组件
二、Django认证系统
http://wuchengyi.com/post/16/
https://www.cnblogs.com/liwenzhou/p/9030211.html