验证参数(JavaBeanValidation)

本文介绍了如何在SpringBoot项目中使用JavaBeanValidation进行参数验证,包括添加依赖、常用注解的使用方法,以及如何在控制器层进行分组验证,以便在添加和修改用户信息时处理不同规则。
摘要由CSDN通过智能技术生成
JavaBeanValidation:验证参数
    1.添加依赖:
        <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-validation -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-validation</artifactId>
            <!--<version>3.2.2</version>-->
        </dependency>
    2.常用的注解:
        @Null // 被注释的元素必须为null
        @NotNull // 被注释的元素不为null
        @AssertTrue // 被注释的元素必须为true
        @AssertFalse // 被注释的元素必须为false
        @Min(value) // 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
        @Max(value) // 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
        @DecimalMin(value) // 被注释的元素必须是一个数字,其值必须大约等于指定的最小值
        @DecimalMax(value) // 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
        @Size(max,min) //被注释的元素的大小必须在指定的范围内
        @Digits(integer,fraction) // 被注释的元素必须是一个数字,其值必须在可接受的范围内
        @Past // 被注释的元素必须是一个过去的日期
        @Future // 被注释的元素必须是一个将来的日期
        @Pattern(value) // 被注释的元素必须符合指定的正则表达式
        @Email // 被注释的元素必须是电子邮箱地址
        @NotEmpty // 被注释的字符串的必须非空

    3.在控制层测试:
        /**
         * 测试spring-boot-starter-validation验证属性
         */
        @GetMapping("/validation")
        public ResultMsg addUser(@Validated User user, BindingResult br) {
            System.out.println("控制层接受的数据: " + user);
            // 验证并获取错误信息
            if (br.hasErrors()) {
                System.out.println("验证为通过的错误信息:");
                List<FieldError> fieldErrors = br.getFieldErrors();
                fieldErrors.forEach(field -> {
                    System.out.println(field.getField() + " ===" + field.getDefaultMessage() );
                });
                return ResultUtils.ERROR(fieldErrors.get(0).getField() + "属性" +
                        fieldErrors.get(0).getDefaultMessage());
            }
            return ResultUtils.SUCCESS();
        }
        注意(添加用户信息、修改用户信息进行分组验证):
            User对象的userName属性加上注解
                @NotEmpty(message = "非空")
                private String userName;
            a) Controller层的参数前面一定要加上@Validated注解
            b) BindingResult br 错误和绑定结果
                br.hasErrors() // 判断时候有错误的信息
                // 有错误信息进行循环
                List<FieldError> fieldErrors = br.getFieldErrors();
                fieldErrors.forEach(field -> {
                    System.out.println(field.getField() + " ===" + field.getDefaultMessage() );
                });
            c) 在添加用户与修改用户的时候一个ID为空,修改时ID不能为空,只能对验证进行分组:
                1.在User实体类中定义两个组:
                    public static interface AddGroup {}
                    public static interface EditGroup {}
                2.在属性验证注解上进行组的标记
                    @NotEmpty(message = "非空", groups = {EditGroup.class})
                    private Integer id;
                3.在userName属性上添加两个组,表示不管是添加还是修改用户信息的时候这两个都需要进行验证:
                    @NotEmpty(message = "非空", groups = {EditGroup.class, AddGroup.class})
                    private Integer userName;
                4.启用验证组:需要在controller层的参数注解上标注@Validated(User.AddGroup.class)
                    表示添加用户信息的时候使用AddGroup组进行验证,这时ID可以为空
                  反之修改时id不能为空:
                  @Validated(User.EditGroup.class)


  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

cocosum

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

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

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

打赏作者

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

抵扣说明:

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

余额充值