Django_Form验证(一)
Django为我们提供了一个模板来做Form验证,不需要我们再去写复杂的验证代码了
简单的提交信息html页面:
<form action="/fff/Form" method="post">
<p><input type="text" name="ac" placeholder="用户名"><span>{{ infor.errors.ac.0 }}</span></p>
<p><input type="password" name="pwd" placeholder="密码"><span>{{ infor.errors.pwd.0 }}</span></p>
<p><input type="text" name="eMail" placeholder="邮箱"><span>{{ infor.errors.eMail.0 }}</span></p>
<p><input type="submit" value="Form提交"></p>
{% csrf_token %}
</form>
解决简单的提示验证问题:
from django import forms #导入包 #开始写模板
class Formsubmit(forms.Form):
ac=forms.CharField(min_length=6,error_messages={"required":"用户名不能为空","min_length":"长度不够"})
pwd=forms.CharField(max_length=10,error_messages={"required":"密码不能为空","max_length":"密码长度过长"})
eMail=forms.EmailField(error_messages={"required":"用户名长度不能为空","invalid":"邮箱格式不对"})
'''
注意:
1.字段的名字要和前段的字段相同,
2.第二个参数就是那种错误显示那种信息,
''' def Form(req):
if req.method=="GET":
return render(req,"Formsubmit.html")
elif req.method=="POST":
obj=Formsubmit(req.POST)#将得到req.POST信息传递给验证类做参数
status=obj.is_valid()#这里执行后才验证,验证的信息都存储在obj这个类中
if status:
rightData=obj.clean()#,去获取正确的信息,这里得到的是一个字典,就可以向数据库里面提交了
# models.xxx.create(**{rightData})
else:
errData=obj.errors#获取错误的信息,存储的是一个继承dict的类.
print(errData["ac"][0])#errDara是一个类,加上['ac']是一个list类,加上[0],就是取第一个错误信息,就是一个字符串了
return render(req,"Formsubmit.html",{"infor":obj})#将信息传递给前段代码
以上就能做到简单的验证.
问题来了:用户实际操作中,如果只有邮箱输入错误了,账号和密码都是正确的,但是一点提交,正确的信息被刷新,必须重新输入,
django当然也考虑到了,所以DjangoForm中还有其他功能.
首先我们自己考虑下,做到用户点提交,页面刷新后还有原来的信息,就必须在刷新后再在我们input框中加上上一次的值,但是我们的Input框自己写死了,所以要动态生成Input框
解决如下:
将html代码的input框动态起来:
<form action="/fff/Form" method="post">
<p>{{ infor.ac }}<span>{{ infor.errors.ac.0 }}</span></p>
<p>{{ infor.pwd }}<span>{{ infor.errors.pwd.0 }}</span></p>
<p>{{ infor.eMail }}<span>{{ infor.errors.eMail.0 }}</span></p>
<p><input type="submit" value="Form提交"></p>
{% csrf_token %}
</form>
后台代码中再GET请求的时候也创建Form对象,但是不传入参数,渲染给页面:
def Form(req):
if req.method=="GET":
obj=Formsubmit()
return render(req,"Formsubmit.html",{"infor":obj})
#其他都不需要修改
这样在执行的时候,就能达到想要的效果.
原因解释:
从动态生成input标签的结果来看,djangoForm对象其实就是为我们自动生成标签(标签有默认和指定的),然后获取值,再验证,再在标签中加入值.这就是他的功能.
流程:
第一次GET提交,Form对象没有拿到值,所以直接生成了空的input标签,--->输入值,POST提交--->Form对象拿到值---->提交后页面刷新,第二次GET请求的时候,Form对象已经拿到值,所以在渲染的时候input框中有上次提交的值.
由此可见前端页面上的Form对象必须都是一致的(列子中就是'infor')
formobj.has_changed()
查看提交的数据是否改变,这个是当我们在处理edit页面的时候比较适合用到,当页面内容没有改变的时候,就不做处理
formobj.changed_data
返回字段列表,查看那些字段改变了,修改起来也比较方便
def Form(req):
if req.method=="GET":
return render(req,"Formsubmit.html")
elif req.method=="POST":
data = {'ac': '', 'pwd': '', 'eMail': '1@1.com'}#c创建initial 作为对比数据 obj=Formsubmit(req.POST,initial=data)#将得到req.POST信息传递给验证类做参数
print('是否改变了;',obj.has_changed())
从form查看表单信息
>>> for row in f.fields.values(): print(row)
...
<django.forms.fields.CharField object at 0x7ffaac632510>
<django.forms.fields.URLField object at 0x7ffaac632f90>
<django.forms.fields.CharField object at 0x7ffaac3aa050>
>>> f.fields['name']
<django.forms.fields.CharField object at 0x7ffaac6324d0>
formobj.cleaned_data
返回'干净'的数据,并且只返回form中定义了的字段,如果是自己额外加的初始化字段,不会返回,并且只返回验证通过了的字段
比如:
>>> data = {'subject': '',
... 'message': 'Hi there',
... 'sender': 'invalid email address',
... 'cc_myself': True}
>>> f = ContactForm(data)
>>> f.is_valid()
False
>>> f.cleaned_data
{'cc_myself': True, 'message': 'Hi there'}#只返回了验证通过的字段
>>> data = {'subject': 'hello',
... 'message': 'Hi there',
... 'sender': 'foo@example.com',
... 'cc_myself': True,
... 'extra_field_1': 'foo',
... 'extra_field_2': 'bar',
... 'extra_field_3': 'baz'}
>>> f = ContactForm(data)
>>> f.is_valid()
True
>>> f.cleaned_data # 没有包含额外添加的字段
{'cc_myself': True, 'message': 'Hi there', 'sender': 'foo@example.com', 'subject': 'hello'}
form快捷显示:
直接打印
print(formobj)
print(formobj.as_p())
...就会看到区别,当然也可以单个字段打印
print(formobj['name'])
Django_Form验证(一)的更多相关文章
- Django_form验证
需求: 当用户向Django后端以post提交数据的时候,无论前端是否进行数据合法验证,后端都需要对客户端提交过来的数据进行数据合法性验证,是否可以利用models中表类字段的约束来实现验证,并且可以 ...
- Django_Form验证(三)字段,字段的参数,widgets种类
Form工具是一个很强大的工具,所以他的功能不仅仅是上面2个例子,这里详细记录一下Form的其他功能 字段的一般参数,以CharFields为列子: user=fields.CharField( re ...
- Django_Form验证(二),ajax验证
还是一个简单的html提交页面,ajax提交就不需要form表单了: <p><input id="a" type="text" name=&q ...
- Django之Form、ModelForm 组件
Django之Form.ModelForm 组件 一.Form组件: django框架提供了一个form类,来处理web开发中的表单相关事项.众所周知,form最常做的是对用户输入的内容进行验证,为此 ...
- python_way day19 HTML-day5 (form表单验证,CSRF,cookie,session,缓存)
python-way day19 1. dJango的form表单验证 2.CSRF 跨站请求伪造 3.cookie,session 4.缓存 一,django表单验证功能 1.django验证基础: ...
- DjangoForm 提交验证
用户提交数据的验证 1.创建模版 -- class LoginForm(forms.Form):.... 2.将请求交给模版,创建一个对象 -- obj = LoginForm(request.POS ...
- 【探索】无形验证码 —— PoW 算力验证
先来思考一个问题:如何写一个能消耗对方时间的程序? 消耗时间还不简单,休眠一下就可以了: Sleep(1000) 这确实消耗了时间,但并没有消耗 CPU.如果对方开了变速齿轮,这瞬间就能完成. 不过要 ...
- C# 中参数验证方式的演变
一般在写方法的时候,第一步就是进行参数验证,这也体现了编码者的细心和缜密,但是在很多时候这个过程很枯燥和乏味,比如在拿到一个API设计文档的时候,通常会规定类型参数是否允许为空,如果是字符可能有长度限 ...
- Yii1.1的验证规则
在Yii1.1的数据验证是由CValidator完成,在CValidator中提供了各种基本的验证规则 <?php public static $builtInValidators=array( ...
随机推荐
- 后台获取用户登录token 和获取前端参数方法
//获取request请求中所有参数 Enumeration<String> names = request.getParameterNames(); HashMap<String, ...
- 本文档教授大家在yii2.0里实现文件上传 首先我们来实现单文件上传
第一步 首先建立一个关于上传的model层 如果你有已经建好的可以使用表单小部件的model层 也可以直接用这个.在这里我们新建一个新的model层 在model层新建文件 Upload.php ...
- ScriptManager 发送错误到客户端
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx. ...
- Linux配置snmp
机器环境 [root@linux-node1 ~]# cat /etc/redhat-release CentOS Linux release 7.1.1503 (Core) [root@linux- ...
- .gitlab-ci.yml 配置文件,知识点
官方介绍:https://docs.gitlab.com/ee/ci/yaml/README.html 翻译: https://segmentfault.com/a/1190000010442764
- 关于各种BUF源语的研究
关于各种BUF源语的研究 资料来源: 单端信号需要用到的BUF 关于这些源语的约束: 增大驱动电流 关于管脚的上拉与下拉约束: ODDR的两种操作模式 关于ODDR输出时钟的应用 为什么ODDR需要这 ...
- VUE打包上线优化
1.将vue vue-router vuex 尽量使用CDN externals: { 'vue':'Vue', 'vue-router':'VueRouter', 'vuex':'Vuex', 'a ...
- VUE中如何优雅的动态绑定长按事件
答案没有: 图片是从后端传过来, 加到imgTarget属性,实现长按点击删除该图片 let img = document.createElement('img'); img.src = " ...
- Java同步学习(持续更新)
在需要考虑线程安全性的场合,可以考虑以下五种方式来实现线程的安全性: 1.同步方法 即有synchronized关键字修饰的方法. 由于java的每个对象都有一个内置锁,当用此关键字修饰方法时, ...
- NodeJs中类定义及类使用
1.首先定义类Point,文件名为point.class.js: // 定义类 class Point { //构造函数 constructor(x, y) { this.x = x;//类中变量 t ...