SpringBoot中@Valid⽅法常⽤注解
使⽤背景
请求数据校验(⽬前我只在这块使⽤过)
使⽤⽅式
在请求实体中加上注解,⽰例:(注意内部类的校验需要额外加上@Valid注解)
@Data
public class Demo1 extends BaReq {
@NotBlank(message = "名称不能为空")
@Length(min = 1, max = 25, message = "名称只能有1-25个字符!")
private String name;
@Valid // 重点在这⾥,⼀定要加上@Valid,Demo2中的校验才会⽣效,否则不会⽣效
@NotNull(message = "列表不能为空")
private List<Demo2> demo2List;
@Data
public static class Demo2{
@NotNull(message = "id不能为空")
private Integer id;
@NotNull(message = "sortNum不能为空")
@Range(min = 0, max = 100, message = "排序值需要介于0 - 100之间")
private Integer sortNum;
}
}
Controller层获取的请求实体需要加上@Valid
// 如果请求类型是json类型(即下⾯的produces对应的值),则需要在请求实体前加上@RequestBody,就会⾃动转成实体对应的属性值,否则会⽆法识别类型从⽽报错
@PostMapping(value = "/add", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
public CommonResult add(@RequestBody @Valid Demo1 demo1Req) { // 重点在这⾥,需要加上@Valid才会去校验
log.info("xxx操作:{}", demo1Req);
// ... rvice对请求做的处理省略
return CommonResult.asSuccess(); // 返回结果
}