Java?@Validated遇到的大坑與處理
Java @Validated 遇到的大坑
我在一個Controller內(nèi),在兩個方法內(nèi)使用@Validated,這是兩個POST方法會進入的方法,這兩個方法的實體類的命名(下圖紅框內(nèi)容)不能一樣,一樣的話就會導致第二個在頁面顯示不出來錯誤信息(第一個可以正常顯示),下圖中的1和3名字不能一樣,2和4名字不能一樣,當出現(xiàn)一樣的情況的時候就會導致頁面顯示不出錯誤信息
Validated注解使用
如果要進行合法性校驗的操作,在類上必須加上@Validated注解
在需要校驗的參數(shù)上,可以使用以下進行校驗:
以下的每一個注解都有一個message屬性,用于指定錯誤原因
例如:
@NotNull(message = "不能為空?。?!") private String firstName;
如果為空時的報錯如下
Property
:person.firstNameValue
:nullReason
:不能為空?。?!
空檢查
@Null
:驗證對象是否為null@NotNull
:驗證對象是否不為null, 無法查檢長度為0的字符串@NotBlank
:檢查約束字符串是不是Null還有被Trim的長度是否大于0,只對字符串,且會去掉前后空格.@NotEmpty
:檢查約束元素是否為NULL或者是EMPTY.
Booelan檢查
@AssertTrue
:驗證 Boolean 對象是否為 true@AssertFalse
:驗證 Boolean 對象是否為 false
長度檢查
@Size(min=, max=)
:驗證對象(Array,Collection,Map,String)長度是否在給定的范圍之內(nèi)@Length(min=, max=)
:Validates that the annotated string is between min and max included.
日期檢查
@Past
:驗證 Date 和 Calendar 對象是否在當前時間之前@Future
:驗證 Date 和 Calendar 對象是否在當前時間之后@Pattern
:驗證 String 對象是否符合正則表達式的規(guī)則
數(shù)值檢查
建議使用在Stirng,Integer類型,不建議使用在int類型上,因為表單值為“”時無法轉(zhuǎn)換為int,但可以轉(zhuǎn)換為Stirng為"",Integer為null
@Min
:驗證 Number 和 String 對象是否大等于指定的值@Max
:驗證 Number 和 String 對象是否小等于指定的值@DecimalMax
:被標注的值必須不大于約束中指定的最大值. 這個約束的參數(shù)是一個通過BigDecimal定義的最大值的字符串表示.小數(shù)存在精度@DecimalMin
:被標注的值必須不小于約束中指定的最小值. 這個約束的參數(shù)是一個通過BigDecimal定義的最小值的字符串表示.小數(shù)存在精度@Digits
:驗證 Number 和 String 的構成是否合法@Digits(integer=,fraction=)
:驗證字符串是否是符合指定格式的數(shù)字,interger指定整數(shù)精度,fraction指定小數(shù)精度。@Range(min=, max=)
:檢查帶值是否介于(包括)指定的最小值和最大值之間。@Valid
:遞歸的對關聯(lián)對象進行校驗, 如果關聯(lián)對象是個集合或者數(shù)組,那么對其中的元素進行遞歸校驗,如果是一個map,則對其中的值部分進行校驗.(是否進行遞歸驗證)@CreditCardNumber
:信用卡驗證@Email
:驗證是否是郵件地址,如果為null,不進行驗證,算通過驗證。@ScriptAssert(lang= ,script=, alias=)
@URL(protocol=,host=, port=,regexp=, flags=)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

仿京東平臺框架開發(fā)開放平臺(包含需求,服務端代碼,SDK代碼)

springboot默認文件緩存(easy-captcha?驗證碼)

SpringBoot+MybatisPlus+Mysql+Sharding-JDBC分庫分表