Java中@valid和@Validated注解的使用詳解
1.簡(jiǎn)介
- @Validated:可以用在類型、方法和方法參數(shù)上。但是不能用在成員屬性(字段)上,不支持嵌套檢測(cè)
- @Valid:可以用在方法、構(gòu)造函數(shù)、方法參數(shù)和成員屬性(字段)上,支持嵌套檢測(cè)
2.引入maven
springboot 2.3.0 以后不會(huì)自動(dòng)引入jar包,所以要添加以下maven,2.3以前則不需要引入maven包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency>
3.配合使用注解
- @Null 限制只能為null
- @NotNull 限制必須不為null
- @AssertFalse 限制必須為false
- @AssertTrue 限制必須為true
- @DecimalMax(value) 限制必須為一個(gè)不大于指定值的數(shù)字
- @DecimalMin(value) 限制必須為一個(gè)不小于指定值的數(shù)字
- @Digits(integer,fraction) 限制必須為一個(gè)小數(shù),且整數(shù)部分的位數(shù)不能超過(guò)integer,小數(shù)部分的位數(shù)不能超過(guò)fraction
- @Future 限制必須是一個(gè)將來(lái)的日期
- @Max(value) 限制必須為一個(gè)不大于指定值的數(shù)字
- @Min(value) 限制必須為一個(gè)不小于指定值的數(shù)字
- @Past 限制必須是一個(gè)過(guò)去的日期
- @Pattern(value) 限制必須符合指定的正則表達(dá)式
- @Size(max,min) 限制字符長(zhǎng)度必須在min到max之間
- @Past 驗(yàn)證注解的元素值(日期類型)比當(dāng)前時(shí)間早
- @NotEmpty 驗(yàn)證注解的元素值不為null且不為空(字符串長(zhǎng)度不為0、集合大小不為0)
- @NotBlank 驗(yàn)證注解的元素值不為空(不為null、去除首位空格后長(zhǎng)度為0),不同于@NotEmpty,@NotBlank只應(yīng)用于字符串且在比較時(shí)會(huì)去除字符串的空格
- @Email 驗(yàn)證注解的元素值是Email,也可以通過(guò)正則表達(dá)式和flag指定自定義的email格式
4.例子
4.1 model
@Valid 定義schoole屬性是為了實(shí)現(xiàn)嵌套驗(yàn)證,沒有這個(gè)注解無(wú)法校驗(yàn)school類內(nèi)部需要校驗(yàn)的屬性。
public class UserVO { @NotNull(message = "id不能為空。" ,groups = {Insert.class}) private Integer id; @NotBlank(message = "name不能為空。",groups = {Update.class}) private String name; @NotNull(message = "schoole不能為空。") @Valid private Schoole schoole; @Min(value = 1,message = "age不能小于1") @Max(value = 130,message = "age不能大于130") private int age; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public Schoole getSchoole() { return schoole; } public void setSchoole(Schoole schoole) { this.schoole = schoole; }
public class Schoole { @NotBlank(message = "name不能為空。",groups = {Update.class}) private String name; @NotNull(message = "id不能為空") private Integer id; public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; }
4.2分組接口
實(shí)現(xiàn)Default 接口,不然@Validated({Update.class}) 使用Update分組時(shí),未定義分組的默認(rèn)校驗(yàn)屬性不會(huì)生效(比如校驗(yàn)schoole的 @NotNull(message = “schoole不能為空。”))
import javax.validation.groups.Default; public interface Insert extends Default { } public interface Update extends Default { }
4.3controller
@Validated 標(biāo)明group 時(shí)(Update.class)只有需要校驗(yàn)屬性上校驗(yàn)注解含有該接口(Update.class)才生效,如果group (Update.class)實(shí)現(xiàn)了Default接口那么需要校驗(yàn)屬性上的校驗(yàn)注解未定義任何group 時(shí)也會(huì)生效。
@RestController @RequestMapping("/valid") public class TestValidController { private static final Logger LOG = LoggerFactory.getLogger(TestValidController.class); @RequestMapping("/test") public void testValid(@Validated({Update.class}) UserVO userVO){ LOG.info("userVo:"+userVO); } @PostMapping("/test2") public void testValid2(@Validated() @RequestBody UserVO userVO){ LOG.info("userVo:"+userVO); } }
4.3.1 基本數(shù)據(jù)類型校驗(yàn)
需要在類上加@Validated,然后方法直接使用@NotNull等校驗(yàn)注解
@Validated public class HrmEmployeeContractController { @Resource private IHrmEmployeeContractService contractService; @GetMapping("/listByEmployeeId2") public ResponseUtil listByEmployeeId2( @NotNull(message = "employeeId 不能為空") Long employeeId) { return ResponseUtil.success(contractService.list(Wrappers.<HrmEmployeeContract>lambdaQuery() .eq(HrmEmployeeContract::getEmployeeId, employeeId) .eq(HrmEmployeeContract::getDeleted, DataStatusEnum.ENABLE.getType()))); } }
4.4使用全局異常攔截器攔截參數(shù)校驗(yàn)異常
MethodArgumentNotValidException異常由@RequestBody 修飾的參數(shù)未校驗(yàn)過(guò)拋出,其他未校驗(yàn)通過(guò)拋出異常BindException。
@RestControllerAdvice public class GlobalExceptionHandler { private Logger LOG= LoggerFactory.getLogger(GlobalExceptionHandler.class); //BindException 校驗(yàn)參數(shù)不滿足條件拋出 @ExceptionHandler(BindException.class) public Object handleValidException(BindException e) { return ResponseUtil.fail(400,e.getBindingResult().getFieldError().getDefaultMessage()); } //MethodArgumentNotValidException @RequestBody 修飾的參數(shù)未校驗(yàn)過(guò)拋出 @ExceptionHandler(MethodArgumentNotValidException.class) public Object handleValidException2(MethodArgumentNotValidException e) { return ResponseUtil.fail(400,e.getBindingResult().getFieldError().getDefaultMessage()); } @ExceptionHandler(RuntimeException.class) @ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR) public ResponseUtil handleRuntimeException(RuntimeException ex) { int code = 500; String message = ex.getMessage(); LOG.error(ex.getMessage(), ex); return ResponseUtil.fail(code,message); } @ExceptionHandler(Exception.class) @ResponseStatus(value = HttpStatus.INTERNAL_SERVER_ERROR) public ResponseUtil handleException(Exception ex) { int code = 500; String message = ex.getMessage(); LOG.error(ex.getMessage(), ex); return ResponseUtil.fail(code,message); } }
測(cè)試
結(jié)果:
Schoole 里面的id 每天報(bào)id不能為空
spring Validation 默認(rèn)會(huì)校驗(yàn)完所有字段,然后拋異常,可以配置快速失敗,一旦校驗(yàn)失敗立馬拋異常。
@Bean public Validator validator(){ ValidatorFactory validatorFactory = Validation.byProvider(HibernateValidator.class).configure() .failFast(true) .buildValidatorFactory(); return validatorFactory.getValidator(); }
到此這篇關(guān)于Java中@valid和@Validated注解的使用詳解的文章就介紹到這了,更多相關(guān)@valid和@Validated注解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
14個(gè)編寫Spring MVC控制器的實(shí)用小技巧(吐血整理)
這篇文章主要介紹了14個(gè)編寫Spring MVC控制器的實(shí)用小技巧(吐血整理),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11java實(shí)現(xiàn)動(dòng)態(tài)圖片效果
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)動(dòng)態(tài)圖片效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03SparkSQL使用IDEA快速入門DataFrame與DataSet的完美教程
本文給大家介紹使用idea開發(fā)Spark SQL 的詳細(xì)過(guò)程,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2021-08-08