springboot中@Validated注解进行校验数据,附详细说明

springboot中@Validated注解进行校验数据,附详细说明

注解说明

空校验针对类型说明
@Null任何类型校验对象必须为空
@NotNull任何类型校验对象不为空,不能校验字符串长度为0的对象
@NotBlank字符串只对字符串有效,校验字符串去掉前后空格后长度不为0
@NotEmpty字符串、集合、数组校验对象不能为空 (字符串长度不为0、集合大小不为0)
boolean校验针对类型说明
@AssertTrue布尔校验boolean类型必须为true
@AssertFalse布尔校验boolean类型必须为false
日期校验针对类型说明
@Past日期类型校验必须是一个过去的日期
@Future日期类型校验必须是一个将来的日期
数值校验针对类型说明
@Min数字类型校验必须是一个数字,其值必须大于或等于指定的最小值
@Max数字类型校验必须是一个数字,其值必须小于或等于指定的最大值
@DecimalMin数字类型校验必须是一个数字,其值必须大于或等于指定的最小值
@DecimalMax数字类型校验必须是一个数字,其值必须小于或等于指定的最大值
@Digits(integer=,fraction=)数字类型校验必须是一个数字,interger指定整数精度,fraction指定小数精度
@Range(min =,max = )数字类型、字符串校验对象的值在min和max区间内
@Length(min =,max = )字符串校验对象的值的长度在min和max区间内
@Size(min =,max = )字符串、集合、数组校验对象的值在min和max区间内,如字符长度、集合大小
其他校验针对类型说明
@Email字符串校验对象的值必须是Email类型,也可以通过regexp和flag指定自定义的email格式
@Pattern字符串校验对象的值必须符合指定的正则表达式
@CreditCardNumber数字类型、字符串校验对象的值必须是信用卡类型
@URL字符串校验对象的值必须是URL地址

@Validated的分组

首先需要根据自己的分组新建分组接口

	/**
	 * 新增数据分组
	 */
	public abstract interface Insert {}
	/**
	 * 修改数据分组
	 */
	public abstract interface Update {}

然后在字段上加入相应的分组

	@ApiModelProperty(value="用户名")
	@NotBlank(message="用户名不能为空" ,groups = {Insert.class, Update.class})
	@Length(min=2,max=20,message = "用户名长度需要在{min}和{max}之间",groups = {Insert.class, Update.class})
	private String username;

最后需要在controller添加你要使用哪个分组进行校验

	@ApiOperation(value = "新增用户", notes = "新增用户")
	@SysLog("新增用户")
	@PostMapping
	public Result save(@RequestBody @Validated({Insert.class}) UserDTO users) {
		return Result.ok(usersService.save(userMps.toDO(users)));
	}
`@Validated`注解是Spring框架提供的一种参数校验注解。它可以用来替代Java标准库的`@Valid`注解,并且支持分组校验等功能。 `@Validated`注解可以用在类、方法、构造函数、方法参数以及方法返回上。它的作用是启用方法参数校验。当方法被调用时,如果参数上标注了`@Validated`注解,则会对该参数进行校验。如果校验失败,则会抛出`MethodArgumentNotValidException`异常。 除了支持Java标准库的参数校验注解之外,`@Validated`注解还支持分组校验功能。即可以根据不同的校验场景,对同一个类的不同属性进行不同的校验。例如: ```java public interface Update { } public interface Create { } public class User { @NotNull(groups = Update.class) private Long id; @NotBlank(groups = {Create.class, Update.class}) private String name; @Min(value = 18, message = "年龄不能小于18岁", groups = {Create.class, Update.class}) private Integer age; // 省略getter和setter方法 } ``` 在上面的代码,定义了两个分组`Create`和`Update`,并在`User`类使用了分组校验注解。其,`id`属性只在更新用户信息时进行校验,`name`和`age`属性在创建和更新用户信息时都需要进行校验。当进行校验时,需要指定对应的分组,例如: ```java @RestController @RequestMapping("/user") @Validated public class UserController { @PostMapping("/create") public ResponseEntity createUser(@RequestBody @Validated(Create.class) User user) { // ... } @PostMapping("/update") public ResponseEntity updateUser(@RequestBody @Validated(Update.class) User user) { // ... } } ``` 在上面的代码,`@Validated(Create.class)`注解表示对`User`对象标注了`Create`分组的属性进行校验,`@Validated(Update.class)`注解表示对`User`对象标注了`Update`分组的属性进行校验。 综上所述,`@Validated`注解可以用来替代Java标准库的`@Valid`注解,并且支持分组校验等功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值