在 Spring Boot 中进行分组校验

本文介绍了如何在SpringBoot3.1.3环境中利用@Validated注解和groups属性进行分组校验,包括默认分组、自定义分组以及分组继承的使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在 Spring Boot 中进行分组校验


前言

环境版本号
springboot 3.1.3
java 17
在 Spring Validation 中,分组是一种通过 @Validated 注解和 groups 属性进行指定的校验方式。默认情况下,如果不指定分组,会使用默认分组进行校验。同时,分组之间可以通过继承关系来复用校验规则。


1.默认分组

代码如下:在没有指定分组的情况下,会使用默认分组进行校验

    public class User {

    @NotBlank(message = "用户名不能为空")
    private String username;

    @NotBlank(message = "密码不能为空")
    private String password;

    // 其他字段...

    // 对应的 getter 和 setter 方法...
}


代码如下:在控制器中,@Valid 注解默认会使用默认分组进行校验。

@RestController
@RequestMapping("/user")
@Validated
public class UserController {

    @PostMapping("/add")
    public ResponseEntity<String> addUser(@Valid @RequestBody User user) {
        // 处理用户添加逻辑
        // ...
        return ResponseEntity.ok("User added successfully");
    }
}



2.自定义分组

代码如下:可以通过定义接口作为分组标识,然后在校验注解的 groups 属性中指定使用哪个分组

   public class User {

    public interface BasicInfoGroup {}
    public interface UpdateInfoGroup {}

    @NotBlank(message = "用户名不能为空", groups = {BasicInfoGroup.class, UpdateInfoGroup.class})
    private String username;

    @NotBlank(message = "密码不能为空", groups = {BasicInfoGroup.class})
    @Size(min = 5, max = 16, message = "密码长度必须在5到16位之间", groups = {BasicInfoGroup.class, UpdateInfoGroup.class})
    private String password;

    // 其他字段...

    // 对应的 getter 和 setter 方法...
}



代码如下:在控制器中使用分组,@Validated(User.BasicInfoGroup.class) 表示在添加用户时只校验 BasicInfoGroup 分组的规则,而 @Validated(User.UpdateInfoGroup.class) 表示在更新用户时只校验 UpdateInfoGroup 分组的规则

@RestController
@RequestMapping("/user")
@Validated
public class UserController {

    @PostMapping("/add")
    public ResponseEntity<String> addUser(@Validated(User.BasicInfoGroup.class) @RequestBody User user) {
        // 处理用户添加逻辑
        // ...
        return ResponseEntity.ok("User added successfully");
    }

    @PutMapping("/update")
    public ResponseEntity<String> updateUser(@Validated(User.UpdateInfoGroup.class) @RequestBody User user) {
        // 处理用户更新逻辑
        // ...
        return ResponseEntity.ok("User updated successfully");
    }
}




3.分组继承

代码如下:分组之间还可以通过继承关系来实现校验规则的复用。

   public class User {

    public interface BasicInfoGroup {}

    public interface UpdateInfoGroup extends BasicInfoGroup {}

    @NotBlank(message = "用户名不能为空", groups = {BasicInfoGroup.class, UpdateInfoGroup.class})
    private String username;

    @NotBlank(message = "密码不能为空", groups = {BasicInfoGroup.class})
    @Size(min = 5, max = 16, message = "密码长度必须在5到16位之间", groups = {BasicInfoGroup.class, UpdateInfoGroup.class})
    private String password;

    // 其他字段...

    // 对应的 getter 和 setter 方法...
}


代码如下:在控制器中使用分组,UpdateInfoGroup 分组继承了 BasicInfoGroup 分组的规则,因此在更新用户时,不仅会校验 UpdateInfoGroup 分组的规则,还会校验 BasicInfoGroup 分组的规则。

@RestController
@RequestMapping("/user")
@Validated
public class UserController {

    @PostMapping("/add")
    public ResponseEntity<String> addUser(@Validated(User.BasicInfoGroup.class) @RequestBody User user) {
        // 处理用户添加逻辑
        // ...
        return ResponseEntity.ok("User added successfully");
    }

    @PutMapping("/update")
    public ResponseEntity<String> updateUser(@Validated(User.UpdateInfoGroup.class) @RequestBody User user) {
        // 处理用户更新逻辑
        // ...
        return ResponseEntity.ok("User updated successfully");
    }
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是行东啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值