django中關於表單自定義驗證器和經常使用驗證器

經常使用驗證器:html

在驗證某個字段的時候,能夠傳遞一個 validators  參數用來指定驗證器,進一步對數據進行過濾。驗證器有不少,可是不少驗證器咱們其實已經經過這個 Field  或者一些參數就能夠指定了。好比 EmailValidator  ,咱們能夠經過 EmailField  來指定,好比 MaxValueValidator  ,咱們能夠經過 max_value  參數來指定。前端

如下是一些經常使用的驗證器:正則表達式

1.  MaxValueValidator  :驗證最大值。數據庫

2.  MinValueValidator  :驗證最小值。json

3.  MinLengthValidator  :驗證最小長度。app

4.  MaxLengthValidator  :驗證最大長度。this

5.  EmailValidator  :驗證是不是郵箱格式。spa

6.  URLValidator  :驗證是不是 URL  格式。code

7.  RegexValidator  :若是還須要更加複雜的驗證,那麼咱們能夠經過正則表達式的驗證orm

器: 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

這樣就能夠把某個字段全部的錯誤信息直接放在這個列表中。

相關文章
相關標籤/搜索