SpringBoot利用@Validated注解優(yōu)雅實(shí)現(xiàn)參數(shù)校驗(yàn)
?一、為什么需要參數(shù)校驗(yàn)
在開(kāi)發(fā) Web 應(yīng)用時(shí),用戶(hù)輸入的合法性校驗(yàn)是保障系統(tǒng)穩(wěn)定性的基礎(chǔ)。傳統(tǒng)做法是通過(guò) if-else 語(yǔ)句逐個(gè)判斷參數(shù),但代碼臃腫、可讀性差且容易遺漏校驗(yàn)邏輯。?Spring Boot 的 @Validated 注解 提供了一種更優(yōu)雅的解決方案,結(jié)合 JSR-303/380 規(guī)范,只需簡(jiǎn)單注解即可實(shí)現(xiàn)復(fù)雜校驗(yàn)。
二、Validated 的核心用法
?1. 基礎(chǔ)校驗(yàn)
在實(shí)體類(lèi)字段上添加校驗(yàn)注解(如 @NotBlank、@Email),并在控制器方法參數(shù)前添加 @Validated,即可自動(dòng)觸發(fā)校驗(yàn)。
示例代碼:
// 實(shí)體類(lèi) public class UserDTO { @NotBlank(message = "用戶(hù)名不能為空") @Size(min = 3, max = 20, message = "長(zhǎng)度需 3-20 位") private String username; @Email(message = "郵箱格式錯(cuò)誤") private String email; } // 控制器 @RestController public class UserController { @PostMapping("/register") public String register(@Validated @RequestBody UserDTO user) { return "注冊(cè)成功!"; // 校驗(yàn)通過(guò)后執(zhí)行 } }
效果: 若參數(shù)不合法,直接返回錯(cuò)誤信息,不會(huì)進(jìn)入方法體。
2. 分組校驗(yàn)
針對(duì)不同場(chǎng)景(如新增、更新)設(shè)置不同校驗(yàn)規(guī)則,通過(guò) groups 參數(shù)實(shí)現(xiàn)精細(xì)化控制。
示例代碼:
public interface ValidationGroups { interface Insert extends Default {} // 新增分組 interface Update extends Default {} // 更新分組 } public class Project { @NotBlank(groups = Update.class, message = "ID 不能為空") private String id; @Min(value = 1000, groups = Insert.class, message = "預(yù)算不能低于 1000") private int budget; } ???????// 控制器 @RestController public class ProjectController { @PostMapping("/add") public String addProject( @Validated(Insert.class) @RequestBody Project project) { return "新增成功!"; } @PostMapping("/modify") public String modifyProject( @Validated(Update.class) @RequestBody Project project) { return "修改成功!"; } }
效果: 新增時(shí)校驗(yàn)預(yù)算,更新時(shí)校驗(yàn) ID。
3. 嵌套校驗(yàn)
對(duì)嵌套對(duì)象進(jìn)行級(jí)聯(lián)校驗(yàn),只需在父對(duì)象字段添加 @Valid(注意:@Validated 無(wú)法直接用于嵌套對(duì)象)。
示例代碼:
public class User { @NotBlank private String name; @Valid private Address address; // 嵌套對(duì)象需加 @Valid } public class Address { @NotBlank private String city; } ???????// 控制器 @PostMapping("/user") public String user(@Validated @RequestBody User user) { return "校驗(yàn)通過(guò)!"; }
效果: 若 address.city 為空,直接返回錯(cuò)誤。
三、進(jìn)階技巧
?1. 自定義校驗(yàn)注解
當(dāng)內(nèi)置注解無(wú)法滿(mǎn)足需求時(shí),可創(chuàng)建自定義注解。例如校驗(yàn)用戶(hù)名唯一性:
步驟:
- 定義注解 @UniqueUsername
- 實(shí)現(xiàn)校驗(yàn)器 UniqueUsernameValidator
代碼片段:
// 自定義注解 @Target({ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) @Constraint(validatedBy = UniqueUsernameValidator.class) public @interface UniqueUsername { String message() default "用戶(hù)名已存在"; } ???????// 校驗(yàn)器 public class UniqueUsernameValidator implements ConstraintValidator<UniqueUsername, String> { @Override public boolean isValid(String username, ConstraintValidatorContext context) { // 調(diào)用數(shù)據(jù)庫(kù)或緩存驗(yàn)證唯一性 return !"admin".equals(username); // 示例邏輯 } }
使用:
public class UserDTO { @UniqueUsername private String username; }
效果: 校驗(yàn)用戶(hù)名是否重復(fù)。
?2. 全局異常處理
通過(guò) @RestControllerAdvice 統(tǒng)一處理校驗(yàn)異常,返回結(jié)構(gòu)化錯(cuò)誤信息:
代碼示例:
@RestControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(MethodArgumentNotValidException.class) public Map<String, String> handleValidationExceptions( MethodArgumentNotValidException ex) { Map<String, String> errors = new HashMap<>(); ex.getBindingResult().getAllErrors().forEach((error) -> { String fieldName = ((FieldError) error).getField(); String errorMessage = error.getDefaultMessage(); errors.put(fieldName, errorMessage); }); return errors; } }
效果: 返回 JSON 格式錯(cuò)誤信息,如 {“username”:“用戶(hù)名不能為空”}。
四、總結(jié)
@Validated 不僅簡(jiǎn)化了參數(shù)校驗(yàn)邏輯,還通過(guò)分組、嵌套校驗(yàn)和自定義注解提供了強(qiáng)大的擴(kuò)展性。結(jié)合全局異常處理,開(kāi)發(fā)者可以專(zhuān)注于業(yè)務(wù)邏輯,而非重復(fù)的校驗(yàn)代碼。
實(shí)踐建議:
在 pom.xml 中添加依賴(lài):
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency>
優(yōu)先使用 @Validated(Spring 特有),復(fù)雜場(chǎng)景結(jié)合 @Valid(Java 標(biāo)準(zhǔn))。
到此這篇關(guān)于SpringBoot利用@Validated注解優(yōu)雅實(shí)現(xiàn)參數(shù)校驗(yàn)的文章就介紹到這了,更多相關(guān)SpringBoot @Validated參數(shù)校驗(yàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot參數(shù)校驗(yàn):@Valid與@Validated使用詳解
- SpringBoot中利用@Valid和@Validated進(jìn)行參數(shù)校驗(yàn)
- springboot @validated List校驗(yàn)失效問(wèn)題
- springboot使用@Validated或@Valid注解校驗(yàn)參數(shù)方式
- SpringBoot項(xiàng)目使用validated實(shí)現(xiàn)參數(shù)校驗(yàn)框架
- SpringBoot參數(shù)校驗(yàn)之@Validated的使用詳解
- SpringBoot @Validated注解實(shí)現(xiàn)參數(shù)分組校驗(yàn)的方法實(shí)例
相關(guān)文章
Java使用RandomAccessFile類(lèi)對(duì)文件進(jìn)行讀寫(xiě)
本篇文章主要介紹了Java使用RandomAccessFile類(lèi)對(duì)文件進(jìn)行讀寫(xiě),詳細(xì)的介紹了RandomAccessFile類(lèi)的使用技巧和實(shí)例應(yīng)用,有興趣的可以了解一下2017-04-04Java 如何使用JDBC連接數(shù)據(jù)庫(kù)
這篇文章主要介紹了Java 如何使用JDBC連接數(shù)據(jù)庫(kù),幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下2021-02-02深入聊一聊springboot項(xiàng)目全局異常處理那些事兒
最近在做項(xiàng)目時(shí)需要對(duì)異常進(jìn)行全局統(tǒng)一處理,所以下面這篇文章主要給大家介紹了關(guān)于springboot項(xiàng)目全局異常處理那些事兒,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01Spring?BeanFactory工廠(chǎng)使用教程
Spring的本質(zhì)是一個(gè)bean工廠(chǎng)(beanFactory)或者說(shuō)bean容器,它按照我們的要求,生產(chǎn)我們需要的各種各樣的bean,提供給我們使用。只是在生產(chǎn)bean的過(guò)程中,需要解決bean之間的依賴(lài)問(wèn)題,才引入了依賴(lài)注入(DI)這種技術(shù)2023-02-02SpringMVC使用MultipartFile 實(shí)現(xiàn)異步上傳方法介紹
這篇文章主要介紹了SpringMVC使用MultipartFile 實(shí)現(xiàn)異步上傳方法介紹,涉及pom依賴(lài)的添加,配置文件的修改等具體操作代碼,需要的朋友可以了解下。2017-09-09java原生序列化和Kryo序列化性能實(shí)例對(duì)比分析
這篇文章主要介紹了java原生序列化和Kryo序列化性能實(shí)例對(duì)比分析,涉及Java和kryo序列化和反序列化相關(guān)實(shí)例,小編覺(jué)得很不錯(cuò),這里分享給大家,希望給大家一個(gè)參考。2017-10-10詳解Spring boot/Spring 統(tǒng)一錯(cuò)誤處理方案的使用
這篇文章主要介紹了詳解Spring boot/Spring 統(tǒng)一錯(cuò)誤處理方案的使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Maven項(xiàng)目如何在pom文件中引入lib下的第三方j(luò)ar包并打包進(jìn)去
在使用Maven進(jìn)行項(xiàng)目開(kāi)發(fā)時(shí),引入第三方私有的Jar包可能會(huì)遇到問(wèn)題,一種常見(jiàn)的解決方案是將Jar包添加到項(xiàng)目的lib目錄,并通過(guò)IDE進(jìn)行配置,但這需要每個(gè)開(kāi)發(fā)者單獨(dú)操作,效率低下,更好的方法是通過(guò)Maven的pom.xml文件管理這些Jar包2024-09-09