Django的Form验证(2)
Django的Form验证(2)
Form的含义及作用:
用于验证用户请求数据合法性的一个组件(校验数据的合法性)
Django的Form实现步骤:
创建一个验证用户请求的模板
from django import forms
class MyForm( forms.Form):
user = forms.CharField(......) input type='text'
email = forms.EmailField(......) input type='email'
pwd = forms.PasswordField(......) input type='password'
类:模板,一共会验证几条数据
字段:用于验证用户某个字段
插件:user = forms.CharField(......widget=Input框) #各种框
获取用户验证请求,进行验证:
-- is_valid() 得到True或False
-- clean() 获取正确数据
-- errors 获取错误信息
Form提交:
errors.字段.0
Ajax提交:
errors.as_json() 字符串类型数据
errors.as_data() 字典类型数据
{'user':[Django对象(),]}
field常用参数:
required = True, 是否必填(重要参数)
widget = None, HTML插件
label = None, 用于生成Label标签或显示内容(也可用于光标显示)
initial = None, 初始值(重要参数)
help_text=' ', 帮助信息(在标签旁边显示)
error_messages=None, 错误信息{'required':'不能为空','invalid':'格式错误'}(重要参数)
show_hidden_initial=False, 是否在当前插件后再加一个隐藏的且具有默认值的插件(可用于检验两次输入是否一致)
validators=[], 自定义验证规则(重要参数)
localize=False, 是否支持本地化
disabled=False, 是否可以编辑
label_suffix=None, label内容后缀
注:error_messages里面的key(code)可以是以下信息出错时的值 {code=min_length message='错误信息'}
CharField(Field):
max_length=None,最大长度;min_length=None,最小长度;strip=True,是否移除用户输入的空白;
IntegerField(Field):
max_value=None,最大值;min_value=None,最小值;max_digits=None,总长度;decimal_places=None,小数位长度
BaseTemporalField(Field):
input_formats=None,时间格式化;
DateField(BaseTemporalField) 格式:2019-12-09
TimeField(BaseTemporalField) 格式:18:51
DateTimeField(BaseTemporalField) 格式:2019-12-09 18:51
DurationField(Field) 时间间隔:%d %H:%M:%S.%f
RegexField(CharField):
regex,自定制正则表达式;max_length=None,最大长度;min_length=None,最小长度;error_message=None,忽略,错误信息使用 error_messages={'invalid':'...'}
EmailField(CharField),同理RegexField方法的使用方式类似
FileField(Field):
allow_empty_file=False,是否允许空文件
ImageField(Field):
注:需要PIL模块,pip3 install Pillow 以上两个字典使用时,需要注意两点:
- form表单中 enctype = "multipart/form-data"
- view函数中 obj = MyForm(request.POST,request.FILES) --->(如果信息和文件都要一起接收要双选)
ChoiceField(Field):
choices=[ ] 选项,如:choices = [(1,'上海'),(2,'北京'),(3,'成都'),]
required=True 是否必填
widget=None 插件,默认select插件
label = None, 用于生成Label标签或显示内容(也可用于光标显示)
initial = None, 初始值(重要参数)
help_text=' ', 帮助信息(在标签旁边显示)
TypedChoiceField(ChoiceField):
coerce = lambda val:val 对选中的值进行一次转换
empty_value=' ' 空的默认值
MultipleChoiceField(): 多选框
ComboField(Field):
fields=[ ] 使用多个验证,例:fields.ComboField(fields=[fields.CharField(max_length=20),fields.EmailField(),])
即验证最大长度20,又验证邮箱格式
MultiValueField(Field):
PS:抽象类,子类中可以实现聚合多个字典去匹配一个值,要配合MultiWidget使用
指自定制验证框(通过继承实现自动生成多个需要的框)
FilePathField(ChoiceField) 文件选项,目录下文件显示在页面中
path 文件夹路径
match=None 正则匹配
recursive=False 递归下面的文件夹
allow_files=True 允许文件
allow_folders=False 允许文件夹
required=True 是否必填
widget=None 插件,默认select插件
label = None, 用于生成Label标签或显示内容(也可用于光标显示)
initial = None, 初始值(重要参数)
help_text=' ', 帮助信息(在标签旁边显示)
GenericIPAddressField
protocol='both', both,ipv4,ipv6支持的IP格式
unpack_ipv4=False 解析ipv4地址,如果是::ffff:192.0.2.1时,可以解析为192.0.2.1,PS:protocol必须为both才能启用
SlugField(CharField) 数字,字母,下划线,减号(连字符)
UUIDField(CharField) uuid类型
注:UUID是根据MAC以及当前时间等创建的不重复的随机字符串
例:
<!-- 前端代码块 -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="/index/" method="POST">
<p>{{ obj.user }}{{ obj.userID }}{{ obj.userChoice }}{{ obj.userChoice2 }}{{ obj.userChoice3 }}</p>
<p>{{ obj.usertype }}{{ obj.userChoice4 }}</p>
<p>{{ obj.usernull }}{{ obj.userlabel.label_tag }}{{ obj.userlabel }}</p>
<p>{{ obj.userinitial }}{{ obj.uservalidators }}{{ obj.userdisable }}{{ obj.usererror }}</p>
<p>{{ obj.usermultiple }}</p>
<p><input type="submit" value="提交"></p>
</form>
</body>
</html>
#后端代码块
#author:wylkjj
#date:2019/12/9
from django.core.validators import RegexValidator
from django.shortcuts import render
from django import forms
from django.forms import widgets
#-*- coding:utf-8 -*-
class myField(forms.Form):
#password属性框
user = forms.CharField(widget=widgets.PasswordInput)
#text属性框
userID = forms.CharField(widget=widgets.TextInput(attrs={'class':'txts','placeholder':'hello!'})) #添加属性
#select属性框第一种书写方式:获取到的值是默认的str类型
userChoice = forms.ChoiceField(choices=[(1,'上海'),(2,'北京'),(3,'成都'),])
#select属性框第二种书写方式: 结合IntegerField() 获取int类型值
userChoice2 = forms.CharField(widget=widgets.Select(choices=[(1,'上海'),(2,'北京'),(3,'成都'),]))
userChoice3 = forms.IntegerField(widget=widgets.Select(choices=[(1,'上海'),(2,'北京'),(3,'成都'),]))
#返回值int属性框
usertype = forms.IntegerField() #数据转换 转换为数字类型,而不是字符串类型,选择框的属性
#互斥select属性框
userChoice4 = forms.IntegerField(widget=widgets.RadioSelect(choices=[(1,'上海'),(2,'北京'),(3,'成都'),]))
#是否允许字段值必填(默认情况下required的值为True,不允许字段无值)
usernull = forms.CharField(required=True)
#显示参数添加光标(label)
userlabel = forms.CharField(label="光标")
#初始值
userinitial = forms.CharField(initial="ppt")
#自定义验证规则(可指定code的名)
uservalidators = forms.CharField(initial="ppt",validators=[RegexValidator(r'^[0-9]+$','11111',code='f1')])
#是否可以进行编辑
userdisable = forms.CharField(initial="ppt",disabled=True)
#错误信息
usererror = forms.CharField(initial="ppt",
max_length=6,
validators=[RegexValidator(r'^[0-9]+$','11111',code='f1')],
error_messages={'required':'不允许为空',
'invalid':'格式错误',
'f1':'asd',
'max_length':'ChaoGuoZuiDaChangDu'})
#多选框
usermultiple = forms.MultipleChoiceField(
initial=[1,2], #初始选中值
choices=[(1,'上海'),(2,'北京'),(3,'成都'),])
def index(request):
if request.method == "GET":
obj = myField()
return render(request, "index.html", {"obj": obj})
elif request.method == "POST":
obj = myField(request.POST)
obj.is_valid()
print(obj.clean())
return render(request, "index.html", {"obj": obj})

Django的Form验证(2)的更多相关文章
- Django的Form验证
Django的Form验证 Form验证:Form提交Form表单数据验证 针对Form提交的数据进行验证 创建模板 class loginForm() 请求提交给模板,创建对象 obj=loginF ...
- Django中Form验证
Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 一,Form验证 第一种操作:主要是这三个函数 ...
- django 使用form验证用户名和密码
form验证可以减少查询数据库,所以代码先预先验证,有问题可以返回给前端显示 1.在users文件夹下新建forms.py文件,用来验证用户名和密码是否为空,密码长度是否大于6 # -*- codin ...
- django的form验证机制
今天遇到了一个奇怪的问题,django中formview一直返回200,但是却没有执行form_valid方法,然后在其中加了一个form_invalid方法: class StudentRegist ...
- Django之Form验证
view.py 配置 from django import forms from django.forms import fields # Create your views here. class ...
- Python Django的分页,Form验证,中间件
本节内容 Django的分页 Form 中间件 1 Django 分页 1.1 Django自带的分页 1.首先来看下我的测试数据环境 ############ models.py ######### ...
- Django form验证
# 模版 class LoginForm(forms.Form): # 模版中的元素 user = forms.CharField(min_length=6,error_messages={" ...
- [py][mx]django form验证-给db减压
django form认证-解压db压力 一般系统都需要前后端都验证 前端验证容器逃逸破解,如通过js console口去发 试想如果后端只有db验证,那么前端无论发什么后端都查询一次db,对db压力 ...
- Django 博客项目02 Form验证+ 上传头像(预览)+Ajax用户注册
头像预览 $("#avatar_file").change(function(){ // 获取上传的文件对象 var file=$(this)[0].files[0]; // 读取 ...
随机推荐
- P2415 集合求和(一道洛谷好题鸭)(虽然可以水过,但有必研究DP)
此题坑点: 结果必须要用long long存,int存不下 如果想要像cout<<sum*pow(2,num-1)这样在输出时计算会错:long long在计算过程被隐式转换成了doubl ...
- 【Android - 组件】之IntentFilter的匹配规则
我们知道,Activity的启动模式分为两种,分别是显式启动和隐式启动.显式启动需要明确的指定被启动的对象的组件信息,包括包名和类名:而隐式启动需要 Intent 能够匹配目标组件的 IntentFi ...
- 计算购物车金额总和( jquery )
今天简单写了一个jq版购物车计算金额总和的例子,如图: 整体页面代码如下: <!DOCTYPE html> <html> <head> <meta chars ...
- DevOps on DevCloud|如何采用流水线践行CI/CD理念【华为云技术分享】
[摘要] 持续集成/持续交付(CI/CD,Continuous Integration/Continuous Deployment)在DevOps CMALS理念中具有支柱性地位,因而CI/CD流水线 ...
- MySQL必知必会(正则表达式)
SELECT prod_name FROM products ' #检索列prod_name包含文本1000的所有行. ORDER BY prod_name; SELECT prod_name FRO ...
- luogu P2812 校园网络【[USACO]Network of Schools加强版】|Tarjan
题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被♂掏♂空,他们来找你帮助他们. 题目描述 共 ...
- 有了 serverless,前端也可以快速开发一个 Puppeteer 网页截图服务
更多云原生技术资讯可关注阿里巴巴云原生技术圈. Puppeteer 是什么? puppeteer 官网的介绍如下: Puppeteer is a Node library which provides ...
- java中List、Map、Set、Stack、Queue、Collections等的使用
java中List.Map.Set.Stack.Queue.Collections等的使用 List 创建方法: List<String> list=new ArrayList<&g ...
- KEIL MDK 算式优先级 备忘
GPRS_SEND_Buff[index++]=stDev.SN>>24+(GPRS_SEND_Buff[4]%4); GPRS_SEND_Buff[index++]=stDev.SN&g ...
- 【Web技术】276- WebView缓存原理分析和应用
前言 混合式开发,在产品体验以及页面加载速度的体验上已经非比以往的.今日早读文章由@unclechen分享. 正文从这开始- 一.背景 现在的App开发,或多或少都会用到Hybrid模式,到了WebV ...