DjangoForm 提交验证
用户提交数据的验证
1.创建模版 -- class LoginForm(forms.Form):....
2.将请求交给模版,创建一个对象 -- obj = LoginForm(request.POST)
3.进行验证 -- obj.is_valid()
4.获取正确的信息 -- obj.clean()
5.获取错误的信息 -- obj.errors
Form 验证
创建一个项目 django_form 和一个应用 app01

创建一个 static 文件夹,放入 jquery.min.js
修改 settings.py 文件
注释下面语句
#'django.middleware.csrf.CsrfViewMiddleware',
在文件最后添加
STATICFILES_DIRS=[
os.path.join(BASE_DIR, "static"),
]
在 urls.py 内容如下
from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
path('admin/', admin.site.urls),
path('login.html', views.login),
]
在 views.py 中修改
class LoginForm(forms.Form):
# 定义元素,需要跟前端提交的名字一致,error_messages 自定义错误信息
user = forms.CharField(min_length=6, error_messages={"required": '用户名不能为空', 'min_length': '用户长度不能小于6'})
email = forms.EmailField(error_messages={"required": '邮箱不能为空', 'invalid': '邮箱格式错误'})
def login(request):
if request.method == 'GET':
# 自动生成 input 标签
obj = LoginForm()
return render(request, 'login.html', {'oo': obj})
elif request.method == 'POST':
# 获取 post 提交过来的所有值
obj = LoginForm(request.POST)
# 判断值是否正确
if obj.is_valid():
# 获取正确的值
value_dict = obj.clean()
print(value_dict)
else:
# 如果错误,错误信息通过 obj 返回前端
pass
return render(request, 'login.html', {'oo': obj})
在 templates 文件夹下添加 login.html 文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>Form提交数据</h1>
<form method="post" action="/login.html">
<p>
{{ oo.user }}
<!-- 通过 oo.errors.user.0 获取错误信息 -->
<span>{{ oo.errors.user.0 }}</span>
</p>
<p>
{{ oo.email }}
<span>{{ oo.errors.email.0 }}</span>
</p>
<p>
<input type="text" name="pwd" placeholder="密码">
</p>
<input type="submit" value="提交">
<input id="ajax_submit" type="button" value="Ajax提交">
</form>
<script src="/static/jquery.min.js"></script>
<script>
$(function () {
$('#ajax_submit').click(function () {
$.ajax({
url: "/login.html",
data: {user:'root', email: 'root@live.com', pwd: '123456'},
type: 'POST',
success:function (arg) {
console.log(arg)
}
})
})
})
</script>
</body>
</html>
当输入的邮箱不正确时,在高级浏览器下后显示如下结果

Ajax 验证
在 urls.py 上修改
path('login_ajax.html', views.login_ajax),
在 views.py 上修改
def login_ajax(request):
if request.method == 'GET':
return render(request, 'login_ajax.html')
elif request.method == 'POST':
ret = {'status': True, 'error': None, 'data': None}
obj = LoginForm(request.POST)
if obj.is_valid():
print(obj.clean())
else:
ret['status'] = False
ret['error'] = obj.errors.as_data() # {'email': [ValidationError(['邮箱格式错误'])], 'user': [ValidationError(['用户长度不能小于6'])]}
return HttpResponse(json.dumps(ret, cls=JsonCustomEncoder))
# 邮箱格式和用户名长度都不正常时,返回给浏览器的是:{"error": {"email": [{"message": "\u90ae\u7bb1\u683c\u5f0f\u9519\u8bef", "code": "invalid"}], "user": [{"message": "\u7528\u6237\u957f\u5ea6\u4e0d\u80fd\u5c0f\u4e8e6", "code": "min_length"}]}, "data": null, "status": false}
# 定义编码类JsonCustomEncoder并重写实例的default函数,对特殊类型进行处理,其余类型继续使用父类的解析。
from django.core.validators import ValidationError
class JsonCustomEncoder(json.JSONEncoder):
def default(self, field):
# 使用 isinstance() 函数来判断 field 是否是 ValidationError 类型
if isinstance(field, ValidationError):
# field 为 ['邮箱格式错误'] 和 ['用户长度不能小于6']
# field.code 为 min_length 和 invalid
# field.message 为 邮箱格式错误 和 用户长度不能小于6
return {'code': field.code, 'message': field.message}
else:
return json.JSONEncoder.default(self, field)
添加 login_ajax.html 文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.error-msg{
color: red;
font-size: 12px;
}
</style>
</head>
<body>
<h1>Ajax提交数据</h1>
<form id="f1" >
<p>
<input id="u" type="text" name="user" placeholder="用户名">
</p>
<p>
<input id="e" type="text" name="email" placeholder="邮箱">
</p>
<p>
<input id="p" type="text" name="pwd" placeholder="密码">
</p>
<input id="ajax_submit" type="button" value="Ajax提交">
</form>
<script src="/static/jquery.min.js"></script>
<script>
$(function () {
$('#ajax_submit').click(function () {
$.ajax({
url: "/login_ajax.html",
data: $('#f1').serialize(), //将表单数据表单序列化(key1=value1&key2=value2…)后提交
type: 'POST',
success:function (arg) {
$('.error-msg').remove();
var v1 = JSON.parse(arg);
console.log(v1);
if(!v1.status){
var error_obj = v1.error;
$.each(error_obj, function (k,v) {
// k: user 或 email
// v: [{}{}{},]
var tag = document.createElement('span');
tag.className = 'error-msg';
tag.innerHTML = v[0].message;
$("input[name='"+ k +"']").after(tag);
})
}else {
location.href = "/index.html"
}
}
})
})
})
</script>
</body>
</html>

DjangoForm 提交验证的更多相关文章
- AngularJS系列:表单全解(表单验证,radio必选,三级联动,check绑定,form提交验证)
一.查看$scope -->寻找Form控制变量的位置 Form控制变量 格式:form的name属性.input的name属性.$... formName.inputField.$pristi ...
- 框架----Django之Form提交验证(一)
一.Form提交验证与Ajax提交验证的运用实例 Form表单提交时会刷新页面,输入失败时,输入框内内容也会随之刷新不能保留:而Ajax提交是在后台偷偷提交,不会刷新页面,因此也就可以保留页面输入框内 ...
- 框架----Django之Form提交验证(二)
一.Form提交验证之(学生表.老师表.班级表)的添加和编辑实现案例 1. 浏览器访问 http://127.0.0.1:8000/student_list/ http://127.0.0.1:800 ...
- 第一百五十四节,封装库--JavaScript,表单验证--提交验证
封装库--JavaScript,表单验证--提交验证 将表单的所有必填项,做一个判断函数,填写正确时返回布尔值 最后在提交时,判断每一项是否正确,全部正确才可以 提交 html <div id= ...
- easyui required 提交验证
使用easyui时,对于提交验证,不不过在标签属性中加入data-options=required:true这句话这么来的.还须要另外加上才写东西能够把验证完整实现 1.设置from的属性 <f ...
- amazeUI表单提交验证--input框required
效果: html: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- 原生JS 表单提交验证器
转载:http://www.cnblogs.com/sicd/p/4613628.html 一.前言 最近在开发一个新项目,需要做登陆等一系列的表单提交页面.在经过“缜密”的讨论后,我们决定 不用外部 ...
- aspx中的表单验证 jquery.validate.js 的使用 以及 jquery.validate相关扩展验证(Jquery表单提交验证插件)
这一期我们先讲在aspx中使用 jquery.validate插件进行表单的验证, 关于MVC中使用 validate我们在下一期中再讲 上面是效果,下面来说使用步骤 jQuery.Valid ...
- js 验证表单 js提交验证类
附加:js验证radio是否选择 <script language="javascript">function checkform(obj){for(i=0;i< ...
随机推荐
- Python—系统模块(os和sys)
os模块 https://www.cnblogs.com/feifeifeisir/p/9519282.html sys模块 获取Python版本信息 import sys a = sys.versi ...
- [Linux] SSH隧道本地端口转发访问远程服务中的数据库
当我的本地没有安装任何数据库服务的时候,可以直接通过我本地的端口访问远程机器上的数据库服务,实现这样的效果就可以使用本地转发功能 实际测试本地端口转发,把本地的9006端口转发给远程服务器的115.1 ...
- 实时SSH网络吞吐量测试
centos 需要epel 源安装pv 软件,debian 需要安装pv 软件 #测试本机到192.168.1.158 的实时速率 yes | pv | ssh 192.168.1.158 " ...
- 【cf600】E. Lomsat gelral(dsu on tree)
传送门 题意: 求子树众数. 思路: \(dsu\ on\ tree\)模板题,用一个桶记录即可. 感觉\(dsu\ on\ tree\)这个算法的涉及真是巧妙呀,保留重链的信息,不断暴力轻边,并且不 ...
- /usr/lib64/python2.7/subprocess.py", line 1327, in _execute_child
https://www.jb51.net/article/142787.htm gn gn 问题如何解决?????
- GraphSage:
https://yq.aliyun.com/articles/712465?type=2 讲了最基本的概念: 1.b.常见的欧几里得结构化数据 将数据转换到欧几里得空间中,所得到的数据称为欧几里得结构 ...
- C getchar()
C getchar() #include <stdio.h> int main() { ; char str[size]; ; char ch; printf("Enter wh ...
- 安装oracle 11g及初次链接使用, 解锁及常用命令
1. 安装方法参考原创: https://blog.csdn.net/projectNo/article/details/76533921 2.初次链接数据库时,注意以下: 1. window + r ...
- CF1221G Graph And Number(容斥,搜索,FMT)
至今觉得这场 edu 的 G 比 EF 都要简单-- 不知道为什么出题人要把 \(m=0\) 放进去,先特判掉. 要求至少一个 \(0\),至少一个 \(1\),至少一个 \(2\),容斥一波,变成总 ...
- CF1207F Koala and Notebook(BFS)
你可能会好奇为什么只有一个 BFS 的标签,却还能够排到 F 的位置. 因为它实在是太 简 单 了 有更新 首先,比较两个数,可以先比较两个数的长度,然后比较两个数看成数字串后的字典序. 不妨先把每条 ...