Spring Boot 数据校验

校验注解

注解说明
@Null限制只能为null
@NotNull限制必须不为null
@AssertTrue限制必须为true
@AssertFalse限制必须为false
@Min(value)限制必须为一个不小于指定值的数字
@Max(value)限制必须为一个不大于指定值的数字
@DecimalMin(value)限制必须为一个不小于指定值的数字
@DecimalMax(value)限制必须为一个不大于指定值的数字
@Digits(integer,fraction)限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Past限制必须是一个过去的日期
@Future限制必须是一个将来的日期
@Size(max,min)限制字符长度必须在min到max之间
@Pattern(value)限制必须符合指定的正则表达式
@NotEmpty验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式

Spring Boot 2.3.0 后需要加该依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-validation</artifactId>
</dependency>

对 User 类校验

public class User {
    @NotNull(message = "用户id不能为空")
    private Integer id;

    @NotBlank(message = "用户名称不能为空")
    @Size(min = 2, max = 10, message = "用户名称长度在2~10之间")
    private String name;

    @NotNull(message = "用户年龄不能为空")
    @Max(value = 150,message = "用户年龄不能大于150")
    @Min(value = 0,message = "用户年龄大于等于0")
    private Integer age;

    @NotBlank(message = "用户地址不能为空")
    private String address;
    
    // getter setter
}

UserController

对象校验 @Valid 要加在参数旁,path和参数校验 @Validated 要加在类上

@RestController
@RequestMapping("/user")
@Validated
public class UserController {
    private Map<Integer, User> userMap = new HashMap<>();

    /**
     * 对象校验 @Valid 要加在参数旁
     * @param user
     */
    @PostMapping("/add")
    public void add(@RequestBody @Valid User user) {
        userMap.put(user.getId(), user);
    }

    /**
     * path校验 @Validated 要加在类上
     * @param id
     * @return
     */
    @GetMapping("/get/{id}")
    public User getByPath(@PathVariable("id") @Min(value = 0,message = "id必须大于0") Integer id) {
        return userMap.get(id);
    }

    /**
     * 参数校验 @Validated 要加在类上
     * @param id
     * @return
     */
    @GetMapping("/get")
    public User getByParam(@Min(value = 0,message = "id必须大于0") Integer id) {
        return userMap.get(id);
    }
}

统一异常处理

@ControllerAdvice 控制器增强,而@RestControllerAdvice相当于@ResponseBody + @ControllerAdvice。

@ExceptionHandler 能拦截特定异常并统一处理,@ResponseStatus 修改Response中的Http状态。

@RestControllerAdvice
public class GlobalExceptionHandler {

    private final Logger logger = LoggerFactory.getLogger(this.getClass());

    /**
     * 对象校验 抛出 MethodArgumentNotValidException 异常
     * @param exception
     * @return
     */
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public Map validationBodyException(MethodArgumentNotValidException exception) {
        BindingResult bindingResult = exception.getBindingResult();
        StringBuilder stringBuilder = new StringBuilder();

        if (bindingResult.hasErrors()) {
            List<ObjectError> errorList = bindingResult.getAllErrors();
            errorList.forEach(error -> {
                logger.error(error.toString());
                stringBuilder.append(error.getDefaultMessage()).append(",");
            });
        }

        Map<String, Object> map = new HashMap<>(2);
        map.put("code", 400);
        map.put("message", stringBuilder.toString().substring(0, stringBuilder.lastIndexOf(",")));
        return map;
    }


    /**
     * path,参数校验 抛出 ConstraintViolationException 异常
     * @param exception
     * @return
     */
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler(ConstraintViolationException.class)
    public Map validationPathException(ConstraintViolationException exception) {
        Set set = exception.getConstraintViolations();
        StringBuilder stringBuilder = new StringBuilder();
        if (!set.isEmpty()) {
            set.forEach(error -> {
                ConstraintViolation constraintViolation = (ConstraintViolation) error;

                logger.error(constraintViolation.toString());

                stringBuilder.append(constraintViolation.getMessage()).append(",");
            });
        }

        Map<String, Object> map = new HashMap<>(2);
        map.put("code", 400);
        map.put("message", stringBuilder.toString().substring(0, stringBuilder.lastIndexOf(",")));
        return map;
    }
}

测试
对象校验
对象校验
path参数校验
path参数校验
参数校验
参数校验

参考:
Validation in Spring Boot
All You Need To Know About Bean Validation With Spring Boot
Spring Boot 数据校验@Validated+统一异常处理
Spring Validation最佳实践及其实现原理

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot提供了参数校验的功能,可以在Controller层对前端传过来的数据进行统一检验。在Spring Boot中,可以使用注解@Valid或@Validated来进行参数校验。\[1\] @Validated注解可以用在类上,表示该类中的方法参数需要进行校验。在Controller类中,可以使用@Validated注解来标注类,然后在方法参数上使用校验注解,比如@NotNull、@Max等,来对参数进行校验。\[1\] 例如,在Controller类中的方法参数上使用@NotNull注解可以校验参数是否为空,使用@Max注解可以校验参数的最大值。如果参数校验不通过,会返回相应的错误信息。\[1\] 参数校验的目的是为了保证数据的安全性和完整性。在web开发中,前端的参数校验是为了提升用户体验,后端的参数校验是为了防止恶意攻击和保护数据的安全。如果没有经过任何校验的参数通过service层、dao层一路来到了数据库,可能会导致严重的后果。因此,参数校验是非常重要的一环。\[2\] 总结来说,Spring Boot提供了参数校验的功能,可以使用@Validated注解校验注解来对Controller层的参数进行校验,以保证数据的安全性和完整性。\[1\]\[2\] #### 引用[.reference_title] - *1* *2* [springBoot参数校验](https://blog.csdn.net/weixin_43947894/article/details/105448716)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [springboot对参数进行校验](https://blog.csdn.net/weixin_44153131/article/details/129011498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值