Django form表单功能的引用(注册,复写form.clean方法 增加 验证密码功能)
1. 在app下 新建 forms.py
定义表单内容,类型models
from django import forms class RegisterForm(forms.Form):
username = forms.CharField(label='用户名', max_length=20) # CharField 对应 html的 input type=text name= 前面的username ,label 对应lable
password = forms.CharField(label='密码',
max_length=12,
min_length=6,
widget=forms.PasswordInput(attrs={'placehodler': # 密码类型的 input
'请输入长度为6-12位的密码'}),
error_messages={ # 定义错误信息 和上面的属性对应.
'min_length': '密码长度小于6位',
'max_length': '密码长度大于12位'
})
password_repeat = forms.CharField(label='再次输入密码', widget=forms.PasswordInput())
email = forms.EmailField()
2. 定义视图,实例化form表单,传到前端
from teatcher.forms import RegisterForm # 导入 自定义form def register(request):
if request.method == 'GET':
form = RegisterForm() # 实例化
return render(request, 'register.html',context={'form': form}) #传到前端
3. 新增url 及 前端 html模板
<body>
<form action="">
{% csrf_token %}
{{ form }} # 显示 表单 内容. form 和 submit 需要手动添加,不在form(只有字段) 范围内.
<input type="submit" value="提交">
</form>
</body>
<body>
<form action="" method='post'>
{{ form.as_p }} # form.as_p 每一行加 <o>标签
<input type="submit" value="提交">
</form>
</body>
# views.py
def register(request):
if request.method == 'GET':
form = RegisterForm()
#return render(request, 'register.html', context={'form': form}) if request.method=='POST':
form = RegisterForm(request.POST) # 从前端获得了数据, 填充了数据的form 实例
if form.is_valid(): # is_valid()自动判断是否满足 form 定义时的条件.true 验证成功
return HttpRespone('注册成功')
return render(request, 'register.html', context={'form': form}) #如果 上面的条件都不满足(中间没有return )执行这一条
# 上面的 is_valid 方法. 调用了 form.clean方法 验证 数据,默认不验证 二个输入密码的一致性. 在forms.py 中 重写 clean方法.继承父类的功能,增加新功能.
# 1定义form 表单, 2 在view 中注册 3.复写 clean 方法(验证信息) from django import forms class RegisterForm(forms.Form):
username = forms.CharField(label='用户名', max_length=20) # CharField 对应 html的 input type=text name= 前面的username ,label 对应lable
password = forms.CharField(label='密码',
max_length=12,
min_length=6,
widget=forms.PasswordInput(attrs={'placehodler': # 密码类型的 input
'请输入长度为6-12位的密码'}),
error_messages={ # 定义错误信息 和上面的属性对应.
'min_length': '密码长度小于6位',
'max_length': '密码长度大于12位'
})
password_repeat = forms.CharField(label='再次输入密码', widget=forms.PasswordInput())
email = forms.EmailField() def clean(self): # 复写父类的方法
# 调用 is_valid 方法的时候,就会去调用 clean方法
clean_data = super().clean() # 保证父类的 clean方法被执行.要这么写. 父类没有验证信息一致性的功能,以下为验证密码(变量名看上面的属性名)
password = clean_data.get('passwrod') # 父类 处理过的数据中 拿到 pssword 变量
password_repeat = clean_data.get('password_repeat') # 父类 处理过的数据中 拿到 password_repeat 变量
if password != password_repeat:
msg = '密码不一致'
self.add_error('password_repeat', msg) # 给属性加了一个 error信息.

Django form表单功能的引用(注册,复写form.clean方法 增加 验证密码功能)的更多相关文章
- Django框架form表单配合ajax注册
总结一下,其实form组件的主要功能如下: 生成页面可用的HTML标签 对用户提交的数据进行校验 保留上次输入内容 下面是写的登录页面的实例 1:views视图中的代码 # 注册页面 def regi ...
- django自带的用户认证和form表单功能
一.用户认证 1.用户认证方法 1.ajango自带用户认证功能,只需要引入相应的模块就可以使用,但是前提是必须使用ajango自带的auth_user表,并且需要把用户相关信息存放在该表中. 2.引 ...
- 基于form表单 写登陆注册
urls urlpatterns = [ url(r'^admin/', admin.site.urls), # 登录界面url(r'^login/$', views.login,name='logi ...
- django之表多对多建立方式、form组件、钩子函数 08
目录 多对多三种创建方式 1.全自动(用ManyToManyField创建第三张表) 2.纯手写 3.半自动 form组件 引入 form组件的使用 forms组件渲染标签 form表单展示信息 fo ...
- form表单上传附件的几种方法
问题描述:在网页开发过程中,当需要上传附件(图片,音频,视频等)时,常规方法是使用form表单进行提交,这里总结一下form表单提交的几种方法. 参考地址:http://www.cnblogs.com ...
- html5之table嵌入form表单布局(务必注意:table标签必须在form表单内部,不能再form表单外部!)
切记:用table标签来布局form表单元素,table标签必须放在form表单内部,否则可能会出现各种bug 原文地址:https://blog.csdn.net/weixin_43343144/a ...
- django 增加验证邮箱功能
在user文件夹下新建python包,utils 在包内新建文件email_send.py,其中包括验证字符串随机码的产生,数据库的存储和email的发送 # -*- coding: utf-8 -* ...
- form 表单onclick事件 禁止表单form提交
最近遇到一次处理form数据的过滤,采用了button的onclick事件来检查,发现return false后表单仍然提交了. 于是仔细研究了下onclick.onsubmit.submit集合函数 ...
- form表单提交后结果乱码的解决方法
1.产生乱码原因:表单提交使用的method="get",get方式数据都是通过地址栏传输,数据会以iso-8859-1方式传输,因此产生乱码 2.概念:URI: Uniform ...
随机推荐
- Azkaban实战,Command类型单一job示例,任务中执行外部shell脚本,Command类型多job工作flow,HDFS操作任务,MapReduce任务,HIVE任务
本文转载自:https://blog.csdn.net/tototuzuoquan/article/details/73251616 1.Azkaban实战 Azkaba内置的任务类型支持comman ...
- 20164310Exp1 PC平台逆向破解和BOF基础
1.逆向及Bof基础实践说明 1.1实践目标 实践对象:pwn1的linux可执行文件 实践目的:使程序执行另一个代码(ShellCode) 实践内容: 手工修改可执行文件,改变程序执行 ...
- sqlserver 已星期一为第一天统计周
本文来源:https://blog.csdn.net/sqlserverdiscovery/article/details/53080695 SELECT GETDATE() AS THEDAY, c ...
- [STM31F103]独立看门狗
独立看门狗步骤: l 取消寄存器写保护: n IWDG_WriteAccessCmd(); l 设置独立看门狗的预分频系数,确定时钟: n IWDG_SetPrescaler(); l 设置看门狗重装 ...
- MySQL计算年龄
SELECT TIMESTAMPDIFF(YEAR, birthday, now()) FROM person2;
- VMware12 安装 Mac OS 10.12 步骤及设置优化教程
最近公司要开发苹果的ARKit应用,但是项目组穷啊,只有美工用着一台苹果本本,所以肯定不能老用他的电脑,效率低还老打扰他.所以我就想着用虚拟机整,毕竟玩了N年的虚拟机了,应该是没啥问题的.所以就开始各 ...
- Angular6 Observable.fromEvent error: “Invalid event target”
今天在angular6项目中写了个拖拽功能,但是控制台报错,如图 后来在控制台打出发现,原来是 ngOnInit( ) 这个生命周期里,页面的dom节点还未产生,还只是null. 改为用 ngAfte ...
- 【学习】数据的加载、存储与文件格式【pandas】
输入输出通常可以划分为几个大类:读取文本文件和其他更高效的磁盘存储格式,加载数据库中的数据,利用web API操作网络资源 1.读写文本格式的数据 pandas提供了一些用于将表格型数据读取为Data ...
- Python2--Pytest_html测试报告优化(解决中文输出问题)
1.报告的输出: pytest.main(["-s","Auto_test.py","--html=Result_test.html"]) ...
- java.lang.NoSuchMethodException: tk.mybatis.mapper.provider.base.BaseSelectProvider.<init>()
这个问题好奇怪, 出现这个错误是通用Mapper初始化的错误,排查的方向就是往这个方向,可能的情况有以下几种: .jar包冲突 <dependency> <groupId>tk ...