springboot validation 分组验证


springboot validation 分组验证

 

应用:同一个pojo在不同的场景下,使用分组对field进行不同的验证

 

 

*************************

示例

 

*******************

pojo 层

 

Num

@Data
public class Num {

    public interface Base{

    }

    public interface Sub extends Base{

    }

    public interface Sub2 extends Base{

    }

    @NotBlank(message = "id 不能为 null")
    private String id;

    @Min(value = 2,message = "base 不能小于 2",groups = {Base.class})
    private Integer base;

    @Min(value = 2,message = "num 不能小于2",groups = {Sub.class})
    private Integer num;

    @Min(value = 2,message = "num2 不能小于 2",groups = {Sub2.class})
    private Integer num2;
}

@NotBlank表示不为空,@NotNull表示不为null,两者不一样

 

*******************

controller 层

 

HelloController

@RestController
public class HelloController {

    @RequestMapping("/hello2")
    public String hello2(@Validated Num num, BindingResult result){
        System.out.println("hello2:"+num);

        if (result.hasFieldErrors()){
            result.getFieldErrors().forEach(error -> {
                System.out.print("field:"+error.getField());
                System.out.println(" ==> message:"+error.getDefaultMessage());
            });
        }

        return "success";
    }

    @RequestMapping("/hello3")
    public String hello3(@Validated({Num.Sub.class}) Num num, BindingResult result){
        System.out.println("hello3:"+num);

        if (result.hasFieldErrors()){
            result.getFieldErrors().forEach(error -> {
                System.out.print("field:"+error.getField());
                System.out.println(" ==> message:"+error.getDefaultMessage());
            });
        }

        return "success";
    }

    @RequestMapping("/hello4")
    public String hello4(@Validated(Num.Sub2.class) Num num, BindingResult result){
        System.out.println("hello4:"+num);

        if (result.hasFieldErrors()){
            result.getFieldErrors().forEach(error -> {
                System.out.print("field:"+error.getField());
                System.out.println(" ==> message:"+error.getDefaultMessage());
            });
        }

        return "success";
    }

    @RequestMapping("/hello5")
    public String hello5(@Validated(Num.Base.class) Num num, BindingResult result){
        System.out.println("hello5:"+num);

        if (result.hasFieldErrors()){
            result.getFieldErrors().forEach(error -> {
                System.out.print("field:"+error.getField());
                System.out.println(" ==> message:"+error.getDefaultMessage());
            });
        }

        return "success";
    }
}

 

 

*************************

使用测试:id(无分组),base(base)、num(sub)、num2(sub2),sub、sub继承base

 

localhost:8080/hello2?id=&base=0&num=0&num2=0

2020-07-14 17:34:07.552  INFO 13896 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2020-07-14 17:34:07.559  INFO 13896 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 7 ms
hello2:Num(id=, base=0, num=0, num2=0)
field:id ==> message:id 不能为 null

@Validated没有指定分组,只对id进行了检验

 

localhost:8080/hello3?id=&base=0&num=0&num2=0

2020-07-14 17:39:28.164  INFO 12556 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2020-07-14 17:39:28.168  INFO 12556 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 4 ms
hello3:Num(id=, base=0, num=0, num2=0)
field:num ==> message:num 不能小于2
field:base ==> message:base 不能小于 2

@Validated指定分组sub,对base、num进行检验

 

localhost:8080/hello4?id=&base=0&num=0&num2=0

2020-07-14 17:44:40.835  INFO 15112 --- [nio-8080-exec-2] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2020-07-14 17:44:40.839  INFO 15112 --- [nio-8080-exec-2] o.s.web.servlet.DispatcherServlet        : Completed initialization in 4 ms
hello4:Num(id=, base=0, num=0, num2=0)
field:base ==> message:base 不能小于 2
field:num2 ==> message:num2 不能小于 2

@Validated指定分组sub2,对base、num2进行检验

 

localhost:8080/hello5?id=&base=0&num=0&num2=0

2020-07-14 17:46:26.017  INFO 13124 --- [nio-8080-exec-2] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2020-07-14 17:46:26.021  INFO 13124 --- [nio-8080-exec-2] o.s.web.servlet.DispatcherServlet        : Completed initialization in 4 ms
hello5:Num(id=, base=0, num=0, num2=0)
field:base ==> message:base 不能小于 2

@Validated指定分组base,对base进行检验

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot 支持使用 JSR-303 Bean Validation 规范来验证请求参数。可以在 Controller 的方法参数上使用 @Valid 注解来验证对应的请求参数。如果验证失败,会抛出 MethodArgumentNotValidException 异常。 ### 回答2: Spring Boot Validation 是 Spring 框架中的一个注解驱动的类库,它实现了对数据的校验功能。通过使用 Spring Boot Validation 可以很方便地进行表单数据验证,从而减少代码的复杂度和错误率。 Spring Boot Validation 主要依靠注解来进行数据的校验,常用的注解包括: @NotNull:验证值不为 null。 @NotEmpty:验证字符串不为空。 @NotBlank:验证字符串不为空白。 @Min:验证数字大小。 @Max:验证数字大小。 @Size:验证字符串或集合长度。 @Valid:表示需要递归验证。 Spring Boot Validation 支持的校验类型十分丰富,可以对 Java 基本数据类型和常见的容器类型进行校验,同时也能自定义校验器验证数据的正确性。 Spring Boot Validation 的应用场景很广泛,主要适用于前后端交互的表单数据处理,可以有效减少非法输入的发生,优化用户体验。另外,在企业级应用中使用 Spring Boot Validation 还可以提高系统的稳定性和安全性,避免因为数据错误导致的系统崩溃或者数据泄露。 总之,Spring Boot Validation 可以使开发人员更加方便地进行数据校验,减少了开发工作量,同时也可以提高系统的效率和安全性。 ### 回答3: Spring Boot是一个全新的框架,它可以简化Spring应用程序的构建和部署。一个典型的Spring Boot应用程序包括许多表单和输入字段,因此数据验证和处理是非常重要的。Spring Boot框架提供了一个称为Validation的表单验证核心组件,因此我们可以很容易地验证用户输入并检查数据的准确性。 Spring Boot中的Validation可以检查输入以确保其满足应用程序的特定要求,并提供与规则不符合的错误消息。这可以帮助我们提高应用程序的健壮性和安全性,并有效地防止恶意用户提交不正确的数据。Validation的基本原则是检查输入是否有效,然后返回相关的错误消息。Spring Boot提供了许多常见的Validation规则,如非空、整数、正数、电子邮件格式等等,并且还允许我们自定义验证规则。通过使用Spring Boot的Validation,我们可以使表单验证更加简单和方便。 在Spring Boot中使用Validation并不复杂,我们只需要在提交表单的控制器中添加@Valid注解,同时将要验证的表单数据传递给BindingResult对象。如果表单数据不符合验证规则,Validation将会自动生成错误消息和细节,并存储在BindingResult对象中。这使得我们可以轻松地通过将错误消息返回到用户界面来提供错误反馈信息。 总而言之,Spring Boot的Validation可以有效地帮助我们创建健壮、安全、正确的应用程序,并使表单验证更加简单和方便。通过使用验证和自定义规则,我们可以确保用户输入的准确性,并最大限度地降低应用程序错误的可能性。因此,对于任何需要表单处理和验证的Spring Boot应用程序,Validation都是一项非常关键的技术。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值