使用javax.validation.constraints對(duì)請(qǐng)求體進(jìn)行統(tǒng)一校驗(yàn)
一、序言
在處理請(qǐng)求的時(shí)候,通常需要對(duì)參數(shù)進(jìn)行校驗(yàn)是否為空,參數(shù)的長(zhǎng)度等進(jìn)行校驗(yàn),
如果在controller層一個(gè)一個(gè)的寫(xiě)校驗(yàn)就很麻煩,于是就有了javax.validation.constraints包。
二、注解類(lèi)型

不同的注解用于不同的數(shù)據(jù)類(lèi)型,小伙伴們可以下載源碼看一些常用的比如非空限制的注解的區(qū)別,
我這里截幾個(gè)圖:



所以我一般的處理是,如果是字符串類(lèi)型就用@NotBlank,
如果是集合數(shù)組之類(lèi)就用@NotEmpty,如果是對(duì)象就用@NotNull
當(dāng)然還有別的包的校驗(yàn)類(lèi)型,比如限制請(qǐng)求參數(shù)的長(zhǎng)度就可以用到另外一個(gè)包里的注解了,在pom中增加依賴:
<dependency> <groupId>org.hibernate.validator</groupId> <artifactId>hibernate-validator</artifactId> <version>6.0.17.Final</version> <scope>compile</scope> </dependency>

三、使用注解
3.1 請(qǐng)求實(shí)體類(lèi)增加注解
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.hibernate.validator.constraints.Length;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
/**
* @author FanHuiFang
* @version 1.0
* @date 2024年04月27日 19:58
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class UserSaveReq {
@NotBlank(message = "name不能為空")
private String name;
@NotNull(message = "年齡不能為空")
private Long age;
@NotEmpty(message = "朋友列表不能為空")
private List<String> friends;
@NotNull(message = "客戶手機(jī)號(hào)不能為空")
@Length(min = 8, max = 16, message = "客戶手機(jī)號(hào)不合法")
private String userPhone;
}
3.2 控制層
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
import org.springframework.validation.Errors;
@PostMapping(value = "/saveUser")
public ResultBean<String> saveUser(@Valid @RequestBody UserSaveReq req, Errors errors) {
if (Objects.isNull(req)) return ResultBean.fail("缺少必要的請(qǐng)求參數(shù)");
if (errors.hasErrors() && Objects.nonNull(errors.getFieldError())) {
String errorMessage = errors.getFieldError().getDefaultMessage();
log.error("保存用戶信息時(shí)請(qǐng)求參數(shù)錯(cuò)誤:{}", errorMessage);
return ResultBean.fail(errorMessage);
}
//保存處理......
}
當(dāng)進(jìn)行請(qǐng)求的時(shí)候,如果缺少某個(gè)參數(shù),或者比如長(zhǎng)度不對(duì),就會(huì)返回異常信息,這樣就不用一個(gè)個(gè)的進(jìn)行校驗(yàn)了。
注意:這里請(qǐng)求參數(shù)中需要加上@Valid注解,如果不加,應(yīng)該是校驗(yàn)沒(méi)有生效的
比如手機(jī)號(hào)號(hào)長(zhǎng)度不對(duì),就會(huì)返回
{
"code": 0,
"message": "客戶手機(jī)號(hào)不合法",
"data": null
}
這里也附帶一下我用的ResultBean,以免看的云里霧里的:
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.ToString;
import java.io.Serializable;
/**
* @author FanHuiFang
* @version 1.0
* @date 2024年04月27日 21:50
*/
@Builder
@Data
@AllArgsConstructor
@ToString
public class ResultBean<T> implements Serializable {
private Integer code;
private String message;
private T data;
public ResultBean(int code, String message, T data) {
this.code = code;
this.data = data;
this.message = message;
}
public ResultBean(Integer code, String message) {
this.code = code;
this.message = message;
}
public static <T> ResultBean<T> data(T data) {
return data("操作成功", data);
}
public static <T> ResultBean<T> data(String message, T data) {
return data(1, message, data);
}
public static <T> ResultBean<T> data(int code, String message, T data) {
return new ResultBean<>(code, message, data);
}
public static <T> ResultBean<T> fail(String message, T data) {
return new ResultBean<>(0, message, data);
}
public static <T> ResultBean<T> fail(Integer code, String message) {
return new ResultBean<>(code, message);
}
public static <T> ResultBean<T> fail(String message) {
return new ResultBean<>(0, message, null);
}
}
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Springboot項(xiàng)目javax.validation使用方法詳解
- java validation 后臺(tái)參數(shù)驗(yàn)證的使用詳解
- java使用Validation進(jìn)行數(shù)據(jù)校驗(yàn)的方式總結(jié)
- JAVA中通過(guò)Hibernate-Validation進(jìn)行參數(shù)驗(yàn)證
- JAVA中的字段校驗(yàn)(validation)
- Java參數(shù)校驗(yàn)中validation和validator的區(qū)別詳解
- Java Validation Api實(shí)現(xiàn)原理解析
- Java Validation Api如何實(shí)現(xiàn)自定義注解
- Javax Validation自定義注解進(jìn)行身份證號(hào)校驗(yàn)
- Java使用validation攔截非法提交的數(shù)據(jù)的方法實(shí)現(xiàn)
相關(guān)文章
java編程創(chuàng)建型設(shè)計(jì)模式工廠方法模式示例詳解
這篇文章主要為大家介紹了java編程創(chuàng)建型設(shè)計(jì)模式之工廠方法模式的創(chuàng)建及案例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-02-02
java利用phantomjs進(jìn)行截圖實(shí)例教程
PlantomJs是一個(gè)基于javascript的webkit內(nèi)核無(wú)頭瀏覽器 也就是沒(méi)有顯示界面的瀏覽器,你可以在基于 webkit 瀏覽器做的事情,它都能做到。下面這篇文章主要給大家介紹了關(guān)于java利用phantomjs進(jìn)行截圖的相關(guān)資料,需要的朋友可以參考下2018-10-10
JavaWeb使用Session和Cookie實(shí)現(xiàn)登錄認(rèn)證
本篇文章主要介紹了JavaWeb使用Session和Cookie實(shí)現(xiàn)登錄認(rèn)證,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03
springboot的controller層的常用注解說(shuō)明
這篇文章主要介紹了springboot的controller層的常用注解說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
java圖片縮放實(shí)現(xiàn)圖片填充整個(gè)屏幕
這篇文章主要介紹了java圖片縮放實(shí)現(xiàn)圖片填充整個(gè)屏幕,本文提供了兩種解決方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05

