偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

SpringBoot接口參數(shù)統(tǒng)一校驗

開發(fā) 架構(gòu)
在進(jìn)行單個參數(shù)校驗時,一定要在Controler類上加@Validated注解,否則校驗不會生效。

SpringBoot檢驗注解

@Null 限制只能為null。

@NotNull 限制必須不為null。

@NotEmpty 只作用于字符串類型,字符串不為空,并且長度不為0。

@NotBlank 只作用于字符串類型,字符串不為空,并且trim()后不為空串。

@AssertFalse 限制必須為false。

@AssertTrue 限制必須為true。

@DecimalMax(value) 限制必須為一個不大于指定值的數(shù)字。

@DecimalMin(value) 限制必須為一個不小于指定值的數(shù)字。

@Digits(integer,fraction) 限制必須為一個小數(shù),且整數(shù)部分的位數(shù)不能超過integer,小數(shù)部分的位數(shù)不能超過fraction。

@Future 限制必須是一個將來的日期。

@Past 驗證注解的元素值(日期類型)比當(dāng)前時間早。

@Max(value) 限制必須為一個不大于指定值的數(shù)字。

@Min(value) 限制必須為一個不小于指定值的數(shù)字。

@Pattern(value) 限制必須符合指定的正則表達(dá)式。

@Size(max,min) 限制字符長度必須在min到max之間。

@Email 驗證注解的元素值是Email,也可以通過正則表達(dá)式和flag指定自定義的email格式。

注意:

@NotNull 適用于任何類型被注解的元素必須不能與NULL。

@NotEmpty 適用于String Map或者數(shù)組不能為Null且長度必須大于0。

@NotBlank 只能用于String上面 不能為null,調(diào)用trim()后,長度必須大于0。

單個參數(shù)校驗

@RestController
@RequestMapping("validator/")
@Validated
public class ValidatorController {
@GetMapping("/add")
public String add(@NotNull(message = "address不能為空") String address) {
return "檢驗通過";
}
}

請求:127.0.0.1:8080/validator/add?address=中國。

返回:檢驗通過。

請求:127.0.0.1:8080/validator/add。

返回:address不能為空。

說明:在進(jìn)行單個參數(shù)校驗時,一定要在Controler類上加@Validated注解,否則校驗不會生效。

實體類參數(shù)校驗

實體User類:

public class User {
@NotBlank(message = "請輸入名稱")
@Length(message = "名稱不能超過個 {max} 字符", max = 5)
public String name;

@NotNull(message = "請輸入年齡")
@Range(message = "年齡范圍為 {min} 到 {max} 之間", min = 1, max = 100)
public Integer age;

public String getName() {return name;}
public void setName(String name) {this.name = name;}
public Integer getAge() {return age;}
public void setAge(Integer age) {this.age = age;}
}

controller類:

@RestController
@RequestMapping("validator/")
public class ValidatorController {
@PostMapping("/add")
public String addUser(@RequestBody @Valid User user, BindingResult bindingResult) {
//查看所有字段是否驗證通過
if (bindingResult.hasErrors()) {
//返回第一條錯誤信息
return bindingResult.getAllErrors().get(0).getDefaultMessage();
}
return "檢驗通過";
}
}

執(zhí)行如下:

說明:如果采用BindingResult方式來存儲異常結(jié)果,就必須自己來處理異常。即接口中有BindingResult參數(shù),就必須使用要有上方7,8,9行代碼進(jìn)行異常處理,否則程序會正常執(zhí)行。

統(tǒng)一異常管理

實體User類,同上。controller類如下:

@RequestMapping("validator/")
public class ValidatorController {
@PostMapping("/add")
public String addUser(@Valid @RequestBody User user) {
return "檢驗通過";
}
}

執(zhí)行結(jié)果:

這里沒有采用BindingResult來存儲異常,程序在這里會報錯??梢栽谶@個地方增加統(tǒng)一異常管理。通過報錯信息可以知道需要對MethodArgumentNotValidException進(jìn)行管理,代碼如下:

@RestControllerAdvice
public class ValidatedExceptionHander {
@ExceptionHandler(MethodArgumentNotValidException.class)
public String MethodArgumentNotValidHandler(MethodArgumentNotValidException exception) {
String exceptionInfo = exception.getBindingResult().getAllErrors().get(0).getDefaultMessage();
return exceptionInfo;
}
}

再次執(zhí)行:

使用spring boot校驗器

檢驗器代碼:

@Component
public class ValidatorUtil implements ApplicationContextAware {
// 通過Spring獲得校驗器
private static Validator validator;

@Override
public void setApplicationContext(ApplicationContext applicationContext){
Validator validatorBean = applicationContext.getBean(Validator.class);
setValidator(validatorBean);
}

public static void setValidator(Validator validatorBean){
if (validatorBean instanceof LocalValidatorFactoryBean) {
validator = ((LocalValidatorFactoryBean) validatorBean).getValidator();
} else if (validatorBean instanceof SpringValidatorAdapter) {
validator = validatorBean.unwrap(Validator.class);
} else {
validator = validatorBean;
}
}

public static <T> void validate(T object){
Set<ConstraintViolation<T>> violationSet = validator.validate(object);
for (ConstraintViolation<T> violation : violationSet) {
throw new ValidationException(violation.getMessage());
}
}
}

統(tǒng)一異常管理:

@RestControllerAdvice
public class ValidatedExceptionHander {
@ExceptionHandler(value = ValidationException.class)
public String ValidationException(ValidationException exception) {
return exception.getMessage();
}
}

controller類如下:

@RestController
@RequestMapping("validator/")
public class ValidatorController {
@PostMapping("/add")
public String addUser(@RequestBody User user) {
ValidatorUtil.validate(user);
return "檢驗通過";
}
}

執(zhí)行如下:

說明:這么做的好處是可以自由的對實體進(jìn)行檢驗,與以上方式相比較為靈活。

分組校驗

同一個實體在不同的操作中的校驗方式是不同的,這就要用到分組校驗。比如實體User在新增操作時,id是沒有的,但是在更新操作時id又必須存在。通過下面例子來講解一下是如何實現(xiàn)的。

實體user:

public class User {
@NotNull(message = "id不能為空", groups = {User.UpdateGroup.class})
@Null(message = "id必須為空", groups = {User.InsertGroup.class})
public Integer id;

@NotBlank(message = "請輸入名稱")
@Length(message = "名稱不能超過個 {max} 字符", max = 5)
public String name;

@NotNull(message = "請輸入年齡")
@Range(message = "年齡范圍為 {min} 到 {max} 之間", min = 1, max = 100)
public Integer 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 Integer getAge() {return age;}
public void setAge(Integer age) {this.age = age;}

public interface InsertGroup{}
public interface UpdateGroup{}
}

統(tǒng)一異常:

@RestControllerAdvice
public class ValidatedExceptionHander {
@ExceptionHandler(MethodArgumentNotValidException.class)
public String MethodArgumentNotValidHandler(MethodArgumentNotValidException exception) {
String exceptionInfo = exception.getBindingResult().getAllErrors().get(0).getDefaultMessage();
return exceptionInfo;
}
}

controller類:

@RestController
@RequestMapping("validator/")
public class ValidatorController {
@GetMapping("/update")
public String updateUser(@Validated(User.UpdateGroup.class) @RequestBody User user) {
return "更新成功";
}
@GetMapping("/insert")
public String insertUser(@Validated(User.InsertGroup.class) @RequestBody User user) {
return "保存成功";
}
}

執(zhí)行如下:

@Validated和@Valid區(qū)別

@Validated 對@Valid 進(jìn)行了二次封裝,但在分組、注解位置、嵌套驗證等功能上有所不同。

不同點

@Valid

@Validated

來源

是Hibernate validation 的 校驗注解

是 Spring Validator 的校驗注解,是 Hibernate validation 基礎(chǔ)上的增加版

注解位置

用在 構(gòu)造函數(shù)、方法、方法參數(shù) 和 成員屬性上

用在 類、方法和方法參數(shù)上。但不能用于成員屬性

嵌套驗證

用在級聯(lián)對象的成員屬性上面

不支持

分組

無此功能

提供分組功能,可以在入?yún)Ⅱ炞C時,根據(jù)不同的分組采用不同的驗證機(jī)制

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2023-03-16 08:23:33

2022-05-30 08:03:06

后端參數(shù)校驗異常處理

2023-11-08 13:33:00

AOP技術(shù)信息

2021-05-18 09:25:54

SpringBoot參數(shù)校驗

2023-11-29 07:23:04

參數(shù)springboto

2020-02-04 18:42:53

充電接口歐盟蘋果

2011-07-19 14:38:06

jQuery Mobi

2024-05-29 08:12:55

接口參數(shù)格式

2022-05-03 10:43:43

SpringJava

2024-10-28 08:32:22

統(tǒng)一接口響應(yīng)SpringBoot響應(yīng)框架

2024-06-13 08:19:08

Controller接口參數(shù)

2024-08-01 09:10:03

2021-08-12 10:32:50

Spring Boot參數(shù)校驗分組校驗

2021-08-10 15:11:27

Spring Boot參數(shù)校驗

2021-11-10 10:03:18

SpringBootJava代碼

2022-05-07 10:09:01

開發(fā)Java日志

2020-03-10 13:13:15

程序員接口參數(shù)編程語言

2025-05-27 07:07:29

2019-09-29 10:23:09

APIJava編程語言

2015-01-27 13:22:55

接口交換機(jī)
點贊
收藏

51CTO技術(shù)棧公眾號