Java中jakarta.validation數(shù)據(jù)校驗(yàn)幾個(gè)主要依賴包講解
概述
在Java中,數(shù)據(jù)校驗(yàn)通常依賴于Bean Validation API,特別是Jakarta Bean Validation(以前的Hibernate Validator)。這個(gè)API允許你在Java對(duì)象上定義和執(zhí)行約束規(guī)則,以確保數(shù)據(jù)的有效性和一致性。以下是有關(guān)jakarta.validation
及其相關(guān)依賴包的詳細(xì)講解:
1. 依賴包
對(duì)于使用Bean Validation API的項(xiàng)目,通常需要添加相關(guān)的依賴包。以Maven為例,通常會(huì)包括以下幾個(gè)主要依賴:
Jakarta Bean Validation API
這是Bean Validation的API規(guī)范定義包,定義了數(shù)據(jù)校驗(yàn)的基本接口和注解。
<dependency> <groupId>jakarta.validation</groupId> <artifactId>jakarta.validation-api</artifactId> <version>3.0.2</version> <!-- 版本可能會(huì)變化 --> </dependency>
Hibernate Validator
這是Bean Validation的一個(gè)實(shí)現(xiàn),提供了API的具體實(shí)現(xiàn)。
<dependency> <groupId>org.hibernate.validator</groupId> <artifactId>hibernate-validator</artifactId> <version>8.0.1.Final</version> <!-- 版本可能會(huì)變化 --> </dependency>
EL (Expression Language) 實(shí)現(xiàn)
Hibernate Validator 可能需要EL實(shí)現(xiàn)來(lái)處理一些注解的表達(dá)式。
<dependency> <groupId>org.glassfish</groupId> <artifactId>javax.el</artifactId> <version>3.0.0</version> <!-- 版本可能會(huì)變化 --> </dependency>
2. 主要注解及其功能
以下是 jakarta.validation
包中一些核心注解的詳細(xì)講解:
@NotNull
- 功能: 確保值不為
null
。 - 用法:
@NotNull private String name;
@Size
- 功能: 驗(yàn)證字符串、集合或數(shù)組的長(zhǎng)度。
- 屬性:
min
: 最小長(zhǎng)度max
: 最大長(zhǎng)度
- 用法:
@Size(min = 2, max = 30) private String username;
@Min 和 @Max
- 功能: 用于設(shè)置數(shù)值的最小值和最大值。
- 屬性:
value
: 最小值(@Min
)或最大值(@Max
)
- 用法:
@Min(18) private int age; @Max(120) private int age;
- 功能: 驗(yàn)證字符串是否符合電子郵件格式。
- 用法:
@Email private String email;
@Pattern
- 功能: 驗(yàn)證字符串是否符合正則表達(dá)式模式。
- 屬性:
regexp
: 正則表達(dá)式
- 用法:
@Pattern(regexp = "\\d{10}") private String phoneNumber;
@Positive 和 @Negative
- 功能: 驗(yàn)證數(shù)值是否為正數(shù)或負(fù)數(shù)。
- 用法:
@Positive private int positiveNumber; @Negative private int negativeNumber;
@Past 和 @Future
- 功能:
@Past
驗(yàn)證日期是否在當(dāng)前日期之前,@Future
驗(yàn)證日期是否在當(dāng)前日期之后。 - 用法:
@Past private LocalDate birthDate; @Future private LocalDate expiryDate;
3. 如何使用
配置和使用Validator
使用Bean Validation API通常涉及以下步驟:
1、創(chuàng)建和配置 ValidatorFactory:
ValidatorFactory factory = Validation.buildDefaultValidatorFactory(); Validator validator = factory.getValidator();
2、驗(yàn)證對(duì)象:
User user = new User(); user.setUsername("A"); user.setAge(17); Set<ConstraintViolation<User>> violations = validator.validate(user); for (ConstraintViolation<User> violation : violations) { System.out.println(violation.getMessage()); }
3、使用Spring Boot集成:
在Spring Boot應(yīng)用中,jakarta.validation
與 spring-boot-starter-validation
自動(dòng)集成。Spring Boot會(huì)自動(dòng)處理帶有注解的Java Bean的驗(yàn)證。
示例:
Java Bean:
import jakarta.validation.constraints.Email; import jakarta.validation.constraints.Min; import jakarta.validation.constraints.NotNull; import jakarta.validation.constraints.Size; public class User { @NotNull(message = "Username cannot be null") @Size(min = 2, max = 30, message = "Username must be between 2 and 30 characters") private String username; @NotNull(message = "Age cannot be null") @Min(value = 18, message = "Age must be at least 18") private Integer age; @Email(message = "Email should be valid") private String email; // Getters and Setters }
Controller:
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; import jakarta.validation.Valid; import org.springframework.http.ResponseEntity; @RestController public class UserController { @PostMapping("/users") public ResponseEntity<String> createUser(@Valid @RequestBody User user) { // 處理有效的user return ResponseEntity.ok("User is valid!"); } }
在這個(gè)示例中,Spring Boot會(huì)自動(dòng)驗(yàn)證請(qǐng)求體中的
User
對(duì)象,并返回相應(yīng)的驗(yàn)證錯(cuò)誤信息(如果有的話)。
4. 定制驗(yàn)證邏輯
你也可以自定義驗(yàn)證邏輯,通過(guò)實(shí)現(xiàn) ConstraintValidator
接口來(lái)創(chuàng)建自定義注解。
示例:
自定義注解:
import jakarta.validation.Constraint; import jakarta.validation.Payload; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Constraint(validatedBy = CustomValidator.class) @Target({ ElementType.METHOD, ElementType.FIELD }) @Retention(RetentionPolicy.RUNTIME) public @interface CustomConstraint { String message() default "Custom validation failed"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; }
自定義驗(yàn)證器:
import jakarta.validation.ConstraintValidator; import jakarta.validation.ConstraintValidatorContext; public class CustomValidator implements ConstraintValidator<CustomConstraint, String> { @Override public void initialize(CustomConstraint constraintAnnotation) {} @Override public boolean isValid(String value, ConstraintValidatorContext context) { // 自定義驗(yàn)證邏輯 return value != null && value.length() > 5; } }
應(yīng)用自定義注解:
public class Example { @CustomConstraint private String customField; }
總結(jié)
jakarta.validation
包及其實(shí)現(xiàn)如 Hibernate Validator 提供了一個(gè)強(qiáng)大的數(shù)據(jù)驗(yàn)證框架,能夠有效地在Java應(yīng)用中確保數(shù)據(jù)的有效性。通過(guò)注解、接口和自定義驗(yàn)證邏輯,你可以靈活地實(shí)現(xiàn)數(shù)據(jù)校驗(yàn),并與Spring Boot等框架集成,以提高應(yīng)用程序的健壯性和用戶體驗(yàn)。
到此這篇關(guān)于Java中jakarta.validation數(shù)據(jù)校驗(yàn)幾個(gè)主要依賴包講解的文章就介紹到這了,更多相關(guān)Java jakarta.validation數(shù)據(jù)校驗(yàn)依賴包內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
純Java代碼實(shí)現(xiàn)流星劃過(guò)天空
本文給大家介紹純java代碼實(shí)現(xiàn)流星劃過(guò)天空,包括流星個(gè)數(shù),流星飛行的速度,色階,流星大小相關(guān)變量設(shè)置。對(duì)java流星劃過(guò)天空特效代碼感興趣的朋友可以參考下本文2015-10-10Springboot整合quartz實(shí)現(xiàn)多個(gè)定時(shí)任務(wù)實(shí)例
這篇文章主要介紹了Springboot整合quartz實(shí)現(xiàn)多個(gè)定時(shí)任務(wù)代碼實(shí)例,Quartz?是一款功能強(qiáng)大的開(kāi)源任務(wù)調(diào)度框架,幾乎可以集成到任何?Java?應(yīng)用程序中,Quartz?可用于創(chuàng)建簡(jiǎn)單或復(fù)雜的任務(wù)調(diào)度,用以執(zhí)行數(shù)以萬(wàn)計(jì)的任務(wù),需要的朋友可以參考下2023-08-08淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案
這篇文章主要介紹了淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02Mybatis中使用updateBatch進(jìn)行批量更新
這篇文章主要介紹了Mybatis中使用updateBatch進(jìn)行批量更新的相關(guān)資料,有逐條更新,sql批量更新等,具體實(shí)例代碼大家參考下本文2018-04-04Spring框架應(yīng)用的權(quán)限控制系統(tǒng)詳解
在本篇文章里小編給大家整理的是關(guān)于基于Spring框架應(yīng)用的權(quán)限控制系統(tǒng)的研究和實(shí)現(xiàn),需要的朋友們可以學(xué)習(xí)下。2019-08-08SpringBoot 指標(biāo)監(jiān)控actuator的專題
未來(lái)每一個(gè)微服務(wù)在云上部署以后,我們都需要對(duì)其進(jìn)行監(jiān)控、追蹤、審計(jì)、控制等。SpringBoot就抽取了Actuator場(chǎng)景,使得我們每個(gè)微服務(wù)快速引用即可獲得生產(chǎn)級(jí)別的應(yīng)用監(jiān)控、審計(jì)等功能,通讀本篇對(duì)大家的學(xué)習(xí)或工作具有一定的價(jià)值,需要的朋友可以參考下2021-11-11