av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

django Model層常用驗證器及自定義驗證器詳解

瀏覽:2日期:2024-09-25 10:40:20

在Django中,對數據進行校驗有兩種方式:一種是通過Form校驗,一種是通過Model校驗。在此,我對Model中的校驗方法做下記錄。

示例之前補充以下幾點:

1、Django數據校驗方式分為以下三步:

Model.clean_fields() 驗證字段基本規則比如長度格式等;

Model.clean() 可自定義驗證條件和報錯信息;

Model.validate_unique() 為驗證添加的唯一性約束。

2、此三步驗證通過調用full_claen(exclude=None, validate_unique=True)來依次執行。

exclude:可以用來指定不需要執行校驗的field。ModelForm也利用這個參數來將field排除。

validate_unique:用來指定是否需要執行Model.validate_unique()。

3、而full_clean()又是通過調用is_valid()方法來執行。

4、save()執行的時候是不會自動調用full_clean()來進行校驗的。

校驗應該在save()執行之前完成,你可以先在form進行校驗,也可以在model中進行校驗。但是,你必須確保通過這兩個校驗之后的數據是絕對沒有問題的“干凈”數據,然后再調用save()方法將數據存儲入庫。

5、校驗中的錯誤處理

我們使用ValidationError來在Model.clean中拋出錯誤,這個錯誤信息將會存儲在以NON_FIELD_ERRORS為key的字典中。這個key是用來存儲對于整個model中的錯誤信息的。

如何獲取校驗的錯誤信息:

from django.core.exceptions import ValidationError, NON_FIELD_ERRORStry: article.full_clean()except ValidationError as e: non_field_errors = e.message_dict[NON_FIELD_ERRORS]

如何指定對于某個特定的field的校驗錯誤信息:

class Article(models.Model): ... def clean(self): if self.status == ’draft’ and self.pub_date is not None: # raise ValidationError({’pub_date’: _(’Draft entries may not have a publication date.’)}) raise ValidationError({’pub_date’: ’Draft entries may not have a publication date.’}) ...

如何指定多個field的校驗錯誤信息:

class Article(models.Model): ... def clean(self): if self.status == ’draft’ and self.pub_date is not None: raise ValidationError({’pub_date’: ’Draft entries may not have a publication date.’, ’creator’: ’Creator can’t be null’}) ...

如何指定全局性校驗錯誤信息:

class Article(models.Model): ... def clean(self): if self.status == ’draft’ and self.pub_date is not None: raise ValidationError(’Draft entries may not have a publication date.’) ...

進入正題:

一、如何使用驗證器:

在驗證某個字段的時候,在模型或者自定義form表單中傳遞一個 validators 參數用來指定驗證器,進一步對數據進行過濾。

或者,通過model中的 Field類型 或者一些參數就可以指定。

比如 EmailValidator ,我們可以通過 指定字段類型為EmailField 來指定。

比如 MaxValueValidator ,我們可以通過 max_value 、max_length參數來指定。

class Interview(models.Model): feedback = models.TextField(max_length=1024, validators=[MinLengthValidator(20, message=’不少于20字’)], verbose_name=’面試反饋’) mail = models.EmailField(max_length=64, blank=True, null=True, verbose_name=’郵箱’) age= models.IntegerField(max_value=64, blank=True, null=True, verbose_name=’年齡’)

二、常用自帶驗證器:

1. MaxValueValidator :驗證最大值。

2. MinValueValidator :驗證最小值。

3. MinLengthValidator :驗證最小長度。

4. MaxLengthValidator :驗證最大長度。

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

6. URLValidator :驗證是否是 URL 格式。

7. RegexValidator :如果還需要更加復雜的驗證,那么我們可以通過正則表達式的驗證。

class Demo(models.Model):telephone = models.CharField(validators=[validators.RegexValidator('1[345678]d{9}',message=’請輸入正確格式的手機號碼!’)])

三、自定義驗證器:

方法:

如果你想要自定義model的校驗,或者想要修改model的屬性的話,就要重寫clean()方法。

class Interview(models.Model): feedback = models.TextField(max_length=1024, validators=[MinLengthValidator(20, message=’不少于20字’)], verbose_name=’面試反饋’) mail = models.EmailField(max_length=64, blank=True, null=True, verbose_name=’郵箱’) age= models.IntegerField(max_value=64, blank=True, null=True, verbose_name=’年齡’ ... def clean(self): if self.result_1 == InterviewResult.FAIL and len(self.feedback) < 20: raise ValidationError({’feedback’: ’不少于20字’})

效果:

django Model層常用驗證器及自定義驗證器詳解

django Model層常用驗證器及自定義驗證器詳解

如果你想做一個全局性的錯誤提示,可以這樣:

... def clean(self): if self.result_1 == InterviewResult.FAIL and len(self.feedback) < 20: raise ValidationError(’不少于20字吧’)

效果:

django Model層常用驗證器及自定義驗證器詳解

以上這篇django Model層常用驗證器及自定義驗證器詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 国产免费一区二区 | 中国毛片免费 | 色婷婷综合在线观看 | 久久久91精品国产一区二区三区 | 九九九视频在线观看 | 国产日韩精品久久 | 2020亚洲天堂 | 视频一区二区在线观看 | 精品国产一区二区三区久久久四川 | 国产一级毛片精品完整视频版 | 国产一级免费在线观看 | 久久成人免费视频 | 中文字幕av免费 | 国产精品一区网站 | 国产乱性 | 黄色一级大片在线免费看产 | 99久久99 | 一级黄色毛片a | 精品1区2区3区 | av午夜电影 | 99热在这里只有精品 | 中文字幕不卡 | 亚洲欧美激情精品一区二区 | 91av视频在线观看 | 99pao成人国产永久免费视频 | 欧美精品在线一区二区三区 | 黄色精品 | www.久久.com| 亚洲欧美另类在线观看 | 日韩视频免费看 | 国产精品久久久久久久久久久新郎 | 日日天天 | 欧美久久不卡 | 欧美成人精品二区三区99精品 | 中文字幕亚洲视频 | 91精品国产一区二区三区香蕉 | 亚洲毛片在线 | av网站免费看 | 欧美中文字幕一区二区三区亚洲 | 91在线一区 | 亚洲精品成人在线 |