django中关于表单自定义验证器和常用验证器

常用验证器:

在验证某个字段的时候,可以传递一个 validators  参数用来指定验证器,进一步对数据进行过滤。验证器有很多,但是很多验证器我们其实已经通过这个 Field  或者一些参数就可以指定了。比如 EmailValidator  ,我们可以通过 EmailField  来指定,比如 MaxValueValidator  ,我们可以通过 max_value  参数来指定。

以下是一些常用的验证器:

1.  MaxValueValidator  :验证最大值。

2.  MinValueValidator  :验证最小值。

3.  MinLengthValidator  :验证最小长度。

4.  MaxLengthValidator  :验证最大长度。

5.  EmailValidator  :验证是否是邮箱格式。

6.  URLValidator  :验证是否是 URL  格式。

7.  RegexValidator  :如果还需要更加复杂的验证,那么我们可以通过正则表达式的验证

器: RegexValidator  。比如现在要验证手机号码是否合格,那么我们可以通过以下代码实

现:

class MyForm(forms.Form):

  telephone = forms.CharField(validators=[validators.RegexValidator("1[345678]\d{9}",message='请输入正确格式的手机号码!')])

 

 

自定义验证:

有时候对一个字段验证,不是一个长度,一个正则表达式能够写清楚的,还需要一些其他复杂的逻辑,那么我们可以对某个字段,进行自定义的验证。比如在注册的表单验证中,我们想要验证手机号码是否已经被注册过了,那么这时候就需要在数据库中进行判断才知道。对某个字段进行自定义的验证方式是,定义一个方法,这个方法的名字定义规则是: clean_fieldname  。如果验证失败,那么就抛出一个验证错误。比如要验证用户表中手机号码之前是否在数据库中存在,那么可以通过以下代码实现:

class MyForm(forms.Form):

  telephone = forms.CharField(validators=[validators.RegexValidator("1[345678]\d{9}",message='请输入正确格式的手机号码!')])

  def clean_telephone(self):

    telephone = self.cleaned_data.get('telephone')

    exists = User.objects.filter(telephone=telephone).exists()

    if exists:

      raise forms.ValidationError("手机号码已经存在!")

    else:

      return telephone

以上是对某个字段进行验证,如果验证数据的时候,需要针对多个字段进行验证,那么可以重写 clean  方法。比如要在注册的时候,要判断提交的两个密码是否相等。那么可以使用以下代码来完成:

class MyForm(forms.Form):

  telephone = forms.CharField(validators=[validators.RegexValidator("1[345678]\d{9}",message='请输入正确格式的手机号码!')])

  pwd1 = forms.CharField(max_length=12)

  pwd2 = forms.CharField(max_length=12)

  def clean(self):

    cleaned_data = super().clean()

    pwd1 = cleaned_data.get('pwd1')

    pwd2 = cleaned_data.get('pwd2')

    if pwd1 != pwd2:

      raise forms.ValidationError('两个密码不一致!')

提取错误信息:

如果验证失败了,那么有一些错误信息是我们需要传给前端的。这时候我们可以通过以下属性来获取:

1.  form.errors  :这个属性获取的错误信息是一个包含了 html  标签的错误信息。

2.  form.errors.get_json_data()  :这个方法获取到的是一个字典类型的错误信息。将某个字段的名字作为 key  ,错误信息作为值的一个字典。

3.  form.as_json()  :这个方法是将 form.get_json_data()  返回的字典 dump  json  格式的字符串,方便进行传输。

4. 上述方法获取的字段的错误值,都是一个比较复杂的数据。比如以下:

{'username': [{'message': 'Enter a valid URL.', 'code': 'invalid'}, {'message': 'Ensurethis value has at most 4 characters (it has 22).', 'code': 'max_length'}]}

那么如果我只想把错误信息放在一个列表中,而不要再放在一个字典中。这时候我们可以定义一个方法,把这个数据重新整理一份。实例代码如下:

class MyForm(forms.Form):

  username = forms.URLField(max_length=4)

  def get_errors(self):

    errors = self.errors.get_json_data()

    new_errors = {}

    for key,message_dicts in errors.items():

      messages = []

      for message in message_dicts:

        messages.append(message['message'])

      new_errors[key] = messages

    return new_errors

这样就可以把某个字段所有的错误信息直接放在这个列表中。

posted on   我是夜雨吖  阅读(2053)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示