Django_form验证

需求:

  当用户向Django后端以post提交数据的时候,无论前端是否进行数据合法验证,后端都需要对客户端提交过来的数据进行数据合法性验证,是否可以利用models中表类字段的约束来实现验证,并且可以进一步对某个单独的字段进行自定义验证,并保存呢?

那,如何满足这个需求呢?

  1. 从Django中 导入forms
  2. 定义一个form类,继承forms.ModelForm
  3. 类中定义一个Meta,指定model=表类名, fields=[ ] 列表中添加想要验证的字段
  4. 在和Meta同级定义一个 def函数,函数名为:clean_字段名 方式进行对某个字段的特殊处理,并可以改变这个字段的属性
  5. view中导入这个form类,实例化时候,把request.POST传递进去,通过object.is_valid()判断是否验证成功,验证失败通过object.errors提交错误信息
  6. form验证成功的数据,放在object.cleaned_data中,以字典的形式存放

    __author__ = ‘beimenchuixue‘
    __blog__ = ‘http://www.cnblogs.com/2bjiujiu/‘
    
    # form.py文件中
    import re
    # 此form验证用户咨询表UserAsk中三个字段,name、mobile、course_name
    # Meta直接利用数据库的约束条件进行字段验证,但是mobile的值要经过特殊验证
    class UserAskFrom(forms.ModelForm):
    
        class Meta:
            model = UserAsk
            fields = [‘name‘, ‘mobile‘, ‘course_name‘]
    
        def clean_mobile(self):
            # 对手机号码进行严格验证clean_+字段名
            mobile = self.cleaned_data[‘mobile‘]
            REGEX_MOBILE = ‘^1[358]\d{9}|^147\d{8}|^176\d{8}$‘
            p = re.compile(REGEX_MOBILE)
            if p.match(mobile):
                return mobile
            else:
                return forms.ValidationError(u‘手机号码错误‘, code=‘mobile_invalid‘)
    
    # view.py文件中
    # view中实例化时候,直接通过实例对象.save(commit=True)保存验证好的数据
    class AddUserAskView(View):
        """课程咨询"""
        def post(self, request):
            # 把request.POST传递进去,要求post的key值和form中fields保持一致
            user_ask_form = UserAskFrom(request.POST)
            if user_ask_form.is_valid():
                # 验证成功直接保存, commit=True 表示提交
                user_ask_form.save(commit=True)
    
    # 对前端传过来的文件,进行验证并且保存,文件传输,必须保证为用户已经验证登录
    # 以用户更换头像为例子,LoginRequiredMixin要求登录的基类 :http://www.cnblogs.com/2bjiujiu/p/7452902.html
    class UpLoadImageView(LoginRequiredMixin, View):
        """更换图片"""
        def post(self, request):
            # 对于上传的文件,放到request.FILES中,instance=request.user指定验证表字段中的一个唯一数据,对该数据有就更新,没有就增加
            image_form = UpLoadImageForm(request.POST, request.FILES, instance=request.user)
            if image_form.is_valid():
                # 自己通过表单对象save方法进行保存数据
                image_form.save()
                # 返回json数据,包含状态码
                return HttpResponse("{‘status‘:‘success‘}", content_type=‘application/json‘)
            else:
                return HttpResponse("{‘status‘:‘fail‘}", content_type=‘application/json‘)
    

      

      

  

  

时间: 2024-10-13 05:08:29

Django_form验证的相关文章

python_way day14 HTML-day5 (form表单验证,)

python-way day19 1. dJango的form表单验证 一,django表单验证功能 1.django验证基础: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>django form</title> </head> <body> <div> <i

python16_day18【Django_Form表单、分页】

一.表单 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 1.Form类 创建Form类时,主要涉及到 [字段] 和 [插件],字段用于对用户请求数据的验证,插件用于自动生成HTML; 所有字段类型: 1 Field 2 required=True, 是否允许为空 3 widget=None, HTML插件 4 label=None, 用于生成Label标签或显示内容 5 initial=N

ASP.NET MVC 使用Remote特性实现远程属性验证

RemoteAttribute是asp.net mvc 的一个验证特性,它位于System.Web.Mvc命名空间 下面通过例子来说明 很多系统中都有会员这个功能,会员在前台注册时,用户名不能与现有的用户名重复,还要求输入手机号码去注册,同时手机号码也需要验证是否重复,下面是实体类 /// <summary> /// 会员 /// </summary> public class Member { public int Id { get; set; } [Required(Error

IE 弹出提示:由于无法验证发布者,所以Windows 已经阻止此软件

由于无法验证发布者,所以Windows 已经阻止此软件 按如下步骤:1.打开Internet Explorer---菜单栏点“工具”---Internet选项--安全---自定义级别---安全设置---“ActiveX控件和插件下”的第5个“下载未签名的ActiveX控件”选择“提示”---确定!刷新您要安装的页面即可(因为使用的软件没有通过微软的徽标认证,在SP2中默认是不允许安装这样的程序的,解决方法为开始-控制面板-系统-硬件.其中在驱动程序项里有有个“驱动程序签名”的选项,点开后.选第一

Oracle基础学习2--Oracle登录与三种验证机制

首先,Oracle安装完毕有三个默认用户 ?  Sys:数据库对象的拥有者.权限最高.password在安装的时候(口令管理)能够改变 ?  System:数据库管理员,password为manager ?  Scott:一个普通用户,password为tiger 再看连接Oracle的三种验证机制 ?  操作系统验证(具体解释见以下) ?  password文件验证 ?  数据库验证 注:前两者适用于系统用户,比方:Sys.System等:最后一个适用于普通用户.比方:Scott. 再看Ora

SpringMVC中文件上传的客户端验证

SpringMVC中文件上传的客户端验证 客户端验证主要思想:在jsp页面中利用javascript进行对文件的判断,完成验证后允许上传 验证步骤:1.文件名称 2.获取文件的后缀名称 3.判断哪些文件类型允许上传 4.判断文件大小 5.满足条件后跳转后台实现上传 前台界面(验证上传文件是否格式满足要求): <body> <h2>文件上传</h2> <form action="upload01" method="post" 

PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证

权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,=>增加一个父控制器验证Session 让所有后台的控制器[除了Login控制器之外的]都继承自这个控制器 5.在管理员访问后台的任何一个页面之前先到数据库中查看当前管理员所在的角色是否有权限访问这个页面 在权限模型中增加此检查方法,在父类登录控制器中调用 6.后台左侧只显示当前管理员有权限访问的按钮

在Laravel中使用Middleware进行身份验证

新建一个中间件: 方法写在handle中 判断用户是否登录而且是否是管理员,不是的话返回到主页 新建判断是否为管理员的方法 在kernel定义一个中间件,key是admin 注册群组路由:prefix是路由前缀,访问路由会自动在前面加上路由前缀:middleware是key值,会去验证中间件 1在数据库中是管理员 成功 附: 注册单个路由的中间件: Route::get('admin/profile', ['middleware' => 'auth', function () { // }]);

利用SHELL脚本来验证Oracle数据库RMAN备份集的有效性

利用SHELL脚本来验证Oracle数据库RMAN备份集的有效性 作者:赵全文  网名:guestart 我们生产环境的Oracle数据库都做了RMAN备份,是采用了一周的RMAN备份保留策略:除了使用RMAN备份以外,我们还使用了爱数(Eisoo)备份软件来进行备份,可以说是做到了有备无患.可是,如果有一天,Oracle数据库由于主机层面硬件原因或是数据库层面的原因不能对外提供高可用服务的时候,假设数据丢了一大部分,我们只有用RMAN备份来进行恢复,再如果发现,RMAN备份失效了,那就往地缝里