SpringBoot利用@Validated注解優(yōu)雅實(shí)現(xiàn)參數(shù)校驗(yàn)
?一、為什么需要參數(shù)校驗(yàn)
在開發(fā) Web 應(yīng)用時(shí),用戶輸入的合法性校驗(yàn)是保障系統(tǒng)穩(wěn)定性的基礎(chǔ)。傳統(tǒng)做法是通過 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í)體類字段上添加校驗(yàn)注解(如 @NotBlank、@Email),并在控制器方法參數(shù)前添加 @Validated,即可自動(dòng)觸發(fā)校驗(yàn)。
示例代碼:
// 實(shí)體類
public class UserDTO {
@NotBlank(message = "用戶名不能為空")
@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)通過后執(zhí)行
}
}
效果: 若參數(shù)不合法,直接返回錯(cuò)誤信息,不會(huì)進(jìn)入方法體。
2. 分組校驗(yàn)
針對(duì)不同場(chǎng)景(如新增、更新)設(shè)置不同校驗(yàn)規(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 無法直接用于嵌套對(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)通過!";
} 效果: 若 address.city 為空,直接返回錯(cuò)誤。
三、進(jìn)階技巧
?1. 自定義校驗(yàn)注解
當(dāng)內(nèi)置注解無法滿足需求時(shí),可創(chuàng)建自定義注解。例如校驗(yàn)用戶名唯一性:
步驟:
- 定義注解 @UniqueUsername
- 實(shí)現(xiàn)校驗(yàn)器 UniqueUsernameValidator
代碼片段:
// 自定義注解
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = UniqueUsernameValidator.class)
public @interface UniqueUsername {
String message() default "用戶名已存在";
}
???????// 校驗(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)用戶名是否重復(fù)。
?2. 全局異常處理
通過 @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”:“用戶名不能為空”}。
四、總結(jié)
@Validated 不僅簡(jiǎn)化了參數(shù)校驗(yàn)邏輯,還通過分組、嵌套校驗(yàn)和自定義注解提供了強(qiáng)大的擴(kuò)展性。結(jié)合全局異常處理,開發(fā)者可以專注于業(yè)務(wù)邏輯,而非重復(fù)的校驗(yàn)代碼。
實(shí)踐建議:
在 pom.xml 中添加依賴:
<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)失效問題
- 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類對(duì)文件進(jìn)行讀寫
本篇文章主要介紹了Java使用RandomAccessFile類對(duì)文件進(jìn)行讀寫,詳細(xì)的介紹了RandomAccessFile類的使用技巧和實(shí)例應(yīng)用,有興趣的可以了解一下2017-04-04
Java 如何使用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)目全局異常處理那些事兒,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01
SpringMVC使用MultipartFile 實(shí)現(xiàn)異步上傳方法介紹
這篇文章主要介紹了SpringMVC使用MultipartFile 實(shí)現(xiàn)異步上傳方法介紹,涉及pom依賴的添加,配置文件的修改等具體操作代碼,需要的朋友可以了解下。2017-09-09
java原生序列化和Kryo序列化性能實(shí)例對(duì)比分析
這篇文章主要介紹了java原生序列化和Kryo序列化性能實(shí)例對(duì)比分析,涉及Java和kryo序列化和反序列化相關(guān)實(shí)例,小編覺得很不錯(cuò),這里分享給大家,希望給大家一個(gè)參考。2017-10-10
詳解Spring boot/Spring 統(tǒng)一錯(cuò)誤處理方案的使用
這篇文章主要介紹了詳解Spring boot/Spring 統(tǒng)一錯(cuò)誤處理方案的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06
Maven項(xiàng)目如何在pom文件中引入lib下的第三方j(luò)ar包并打包進(jìn)去
在使用Maven進(jìn)行項(xiàng)目開發(fā)時(shí),引入第三方私有的Jar包可能會(huì)遇到問題,一種常見的解決方案是將Jar包添加到項(xiàng)目的lib目錄,并通過IDE進(jìn)行配置,但這需要每個(gè)開發(fā)者單獨(dú)操作,效率低下,更好的方法是通過Maven的pom.xml文件管理這些Jar包2024-09-09

