網站首頁 編程語言 正文
一、怎么校驗創建的項目名是否是唯一的,當項目名name字段不唯一,怎么設置提示信息?
class ProjectsSerializer(serializers.Serializer):
create_time=serializers.DateTimeField(label='創建時間',help_text='創建時間',
format='%Y年%m月%d日 %H時%M分%S秒',read_only=True)
update_time = serializers.DateTimeField(label='更新時間', help_text='更新時間',
format='%Y年%m月%d日 %H時%M分%S秒', read_only=True)
name=serializers.CharField(label='項目名稱',help_text='項目名詞',
max_length=20,min_length=3,
error_messages={'min_length':'項目名稱不能少于3位',
'max_length':'項目名稱不能大于20'},
validators=[UniqueValidator(queryset=Projects.objects.all(),message='項目名稱不能重復')])
??tip1:校驗規則
1、可以在序列化器字段上使用validators指定自定義校驗規則
2、validators必須得為序列類型(一般為列表),在列表中可以添加多個校驗規則
3、DRF框架自帶UniqueValidator校驗器,必須得使用queryset指定查詢集對象,用于對該字段進行校驗
4、UniqueValidator校驗器,可以使用message指定自定義報錯信息
5、校驗規則的執行順序?
先對字段類型進行校驗(CharField)——》依次驗證validators列表中的校驗規則——》從右到左依次驗證其他規則——》調用單字段校驗方法(如果有定義)
二、項目名稱中必須得包含“項目”2字
def is_contains_keyword(value):
is '項目' not in value:
raise serializers.ValidationError("項目名稱中必須包含'項目'關鍵字")
class ProjectsSerializer(serializers.Serializer):
create_time=serializers.DateTimeField(label='創建時間',help_text='創建時間',
format='%Y年%m月%d日 %H時%M分%S秒',read_only=True)
update_time = serializers.DateTimeField(label='更新時間', help_text='更新時間',
format='%Y年%m月%d日 %H時%M分%S秒', read_only=True)
name=serializers.CharField(label='項目名稱',help_text='項目名詞',
max_length=20,min_length=3,
error_messages={'min_length':'項目名稱不能少于3位',
'max_length':'項目名稱不能大于20'},
validators=[UniqueValidator(queryset=Projects.objects.all(),message='項目名稱不能重復'),is_contains_keyword])
??tip2:校驗規則
1、可以在類外面自定義校驗函數
2、第一個參數為待校驗的值(name)
3、如果校驗不通過,必須得拋出serializers.ValidationError(‘報錯信息’)異常,同時可以指定具體得報錯信息
4、需要將校驗函數名放置到某一個字段的 validators列表中(不加括號)
三、單個字段進行校驗:項目名稱不能多于10個字
def is_contains_keyword(value):
is '項目' not in value:
raise serializers.ValidationError("項目名稱中必須包含'項目'關鍵字")
class ProjectsSerializer(serializers.Serializer):
create_time=serializers.DateTimeField(label='創建時間',help_text='創建時間',
format='%Y年%m月%d日 %H時%M分%S秒',read_only=True)
update_time = serializers.DateTimeField(label='更新時間', help_text='更新時間',
format='%Y年%m月%d日 %H時%M分%S秒', read_only=True)
name=serializers.CharField(label='項目名稱',help_text='項目名詞',
max_length=20,min_length=3,
error_messages={'min_length':'項目名稱不能少于3位',
'max_length':'項目名稱不能大于20'},
validators=[UniqueValidator(queryset=Projects.objects.all(),message='項目名稱不能重復'),is_contains_keyword])
class Meta:
model=Projects
fields='__all__'
def validate_name(self,attr:str):
if len(attr)>10:
raise serializers.ValidationError('項目名稱不能多于10個字')
return attr
??tip3:校驗規則
1、可以在序列化器類中對單個字段進行校驗
2、但字段得校驗方法名稱,必須把validate_作為前綴,加上待校驗得字段名,如:validate_待校驗得字段名
3、如果校驗不通過必須得返回serializers.ValidationError(‘具體得報錯信息’)
4、如果校驗通過,往往將校驗之后得值返回
5、如果該字段在定義時添加得校驗規則不通過,那么是不會進行單字段校驗的;如果能對單字段進行校驗說明上面是校驗通過的。
6、必須返回attr(當然如果不返回attr也不會報錯)
四、多字段進行校驗:
class RegisterModelSerializer(serializers.ModelSerializer):
password_confirm = serializers.CharField(label='確認密碼', help_text='確認密碼',
error_messages={"min_length": "允許輸入5-20個字符",
"max_length": "允許輸入5-20個字符", },
write_only=True)
token = serializers.CharField(label='token', help_text='token', read_only=True)
class Meta:
model = User
fields = ['id', 'username', 'password', 'password_confirm', 'token', 'email']
# 校驗密碼與驗證碼密碼
def validate(self, attrs):
password=attrs.get('password')
password=attrs.get('password_confirm')
if password!=password_confirm:
raise serializers.ValidationError('密碼和確認密碼不一致')
return attrs
??tip4:校驗規則
1、可以在序列化器類中對多個字段進行聯合校驗
2、使用固定得validate方法,會接受上面校驗通過之后得字典數據
3、當所有字段定義時添加的校驗規則都通過,并且每個字典得單字段校驗通過得情況下,才會調用validate方法
4、必須返回attrs
五、to_internal_value方法,是所有字段開始進行校驗時的入口方法(最先調用的方法)
class InterfacesSerializer(serializers.ModelSerializer):
project=serializer.StringRelatedField(label='接口所屬項目',help_text='接口所屬項目',read_only=True)
project_id=serializer.PrimaryKeyRelatedField(label='接口所屬項目id',help_text='接口所屬項目id',queryset=Projects.objects.all(),write_only=True)
class Meta:
model=Interfaces
fields=['id','name','tester','project','create_time','desc','project_id']
#exclude=['update_time']
extra_kwargs={
"create_time":{
"read_only":True,
"format":"%Y年%m月%d日 %H:%M:%S",
}
}
def to_internal_value(self,data):
result=super().to_intrenal_value(data)
result['project_id']=result.get('project_id').id
return result
六、to_representation方法,是序列化輸出的入口方法
校驗順序為:首先對字段類型進行校驗——》依次驗證validators列表中的校驗規則——》從右到左驗證其他的校驗規則——》調用單字段校驗方法(如果有定義)——》調用多字段聯合調用validate方法
原文鏈接:https://blog.csdn.net/YZL40514131/article/details/125006687
相關推薦
- 2023-01-11 解決?Redis?數據傾斜、熱點等問題_Redis
- 2024-01-05 TCP、IP、TCP/IP、HTTP和HTTPS協議簡介
- 2022-04-27 Oracle?觸發器trigger使用案例_oracle
- 2022-10-15 C#集合本質之隊列的用法詳解_C#教程
- 2022-11-05 安裝ingress-nginx遇到的一些坑實戰記錄_云其它
- 2023-02-03 使用PyGame顯示圖像的四種方案實例代碼_python
- 2022-03-15 Spring Boot 是如何控制版本和自動配置的
- 2022-09-01 C#實現簡單工廠模式_C#教程
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支