SpringBoot ~ 数据校验

  1. 添加pom依赖

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>
    
  2. 编写实体类

    /**
     * @author wsyjlly
     * @create 2019.06.29 - 12:18
     **/
    @AllArgsConstructor
    @NoArgsConstructor
    @Accessors
    @Data
    @TableName(value = "message")
    public class Message implements Serializable {
        private Integer id;
        private Integer mid;
    
        @Size(min = 5,max = 10,message = "{message.content.size}")
        @NotNull(message = "{message.content.notnull}")
        private String content;
    
        @Size(min = 5,max = 10,message = "{message.column1.size}")
        @NotNull(message = "{message.column1.notnull}")
        @TableField(value = "column_200")
        private String column1;
    
        @Size(min = 5,max = 10,message = "{message.column2.size}")
        @NotNull(message = "{message.column2.notnull}")
        @TableField(value = "column_500")
        private String column2;
    
        @Size(min = 5,max = 10,message = "{message.column3.size}")
        @NotNull(message = "{message.column3.notnull}")
        @TableField(value = "column_5000")
        private String column3;
    }
    
  3. ValidationMessages.properties配置

    message.content.notnull=该字段不能为空
    message.column1.notnull=该字段不能为空
    message.column2.notnull=该字段不能为空
    message.column3.notnull=该字段不能为空
    message.content.size=内容长度过短
    message.column1.size=内容长度过短
    message.column2.size=内容长度过短
    message.column3.size=内容长度过短
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vruNTMc5-1591538967208)(./assets/1563358182687.png)]

  4. Controller校验

    /**
     * @author wsyjlly
     * @create 2019.07.17 - 17:34
     **/
    @RestController
    @RequestMapping("/message")
    public class MessageController {
        @PostMapping("/validate")
        public List validate(@RequestBody @Validated Message message, BindingResult result){
            System.out.println(message);
            ArrayList<Object> list = new ArrayList<>();
            if (result.hasErrors()) list.addAll(result.getAllErrors());
            for (ObjectError item : result.getAllErrors()){
                System.out.println(item);
            }
            list.add(message);
            return list;
        }
    }
    
  5. 分组校验

    • 创建分组接口

      /**
       * @author wsyjlly
       * @create 2019.07.17 - 18:29
       **/
      @Component
      public interface ValidationGroup1 {}
      
      /**
       * @author wsyjlly
       * @create 2019.07.17 - 18:29
       **/
      @Component
      public interface ValidationGroup2 {}
      
    • 实体类添加分组

      /**
       * @author wsyjlly
       * @create 2019.06.29 - 12:18
       **/
      @AllArgsConstructor
      @NoArgsConstructor
      @Accessors
      @Data
      @TableName(value = "message")
      public class Message implements Serializable {
          private Integer id;
          private Integer mid;
      
          @Size(min = 5,max = 10,message = "{message.content.size}")
          @NotNull(message = "{message.content.notnull}")
          private String content;
      
          @Size(min = 5,max = 10,message = "{message.column1.size}")
          @NotNull(message = "{message.column1.notnull}")
          @TableField(value = "column_200")
          private String column1;
      
          @Size(min = 5,max = 10,message = "{message.column2.size}",groups = ValidationGroup1.class)
          @NotNull(message = "{message.column2.notnull}")
          @TableField(value = "column_500")
          private String column2;
      
          @Size(min = 5,max = 10,message = "{message.column3.size}",groups = {ValidationGroup1.class, ValidationGroup2.class})
          @NotNull(message = "{message.column3.notnull}")
          @TableField(value = "column_5000")
          private String column3;
      }
      
    • Controller校验指定分组

      /**
       * @author wsyjlly
       * @create 2019.07.17 - 17:34
       **/
      @RestController
      public class ValidateController {
      
          @PostMapping("/validate1")
          public List validate(@RequestBody @Validated Message message, BindingResult result){
              System.out.println(message);
              ArrayList<Object> list = getObjects(result);
              list.add(message);
              return list;
          }
          
          @PostMapping("/validate2")
          public List validate2(@RequestBody @Validated(ValidationGroup1.class) Message message, BindingResult result){
              System.out.println(message);
              ArrayList<Object> list = getObjects(result);
      list.add(message);
              return list;
          }
          
          @PostMapping("/validate3")
          public List validate3(@RequestBody @Validated(ValidationGroup2.class) Message message, BindingResult result){
              System.out.println(message);
              ArrayList<Object> list = getObjects(result);
              list.add(message);
              return list;
          }
      
          private ArrayList<Object> getObjects(BindingResult result) {
              ArrayList<Object> list = new ArrayList<>();
              if (result.hasErrors()) {
                  for (ObjectError item : result.getAllErrors()) {
                      list.add(item.getDefaultMessage());
                      System.out.println(item.getDefaultMessage());
                  }
              }
              return list;
          }
      }
      

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot提供了很方便的数据校验功能,可以通过注解方式实现。要使用数据校验功能,首先需要在项目的pom.xml文件中添加相关的依赖。其中,我们可以使用spring-boot-starter-validation依赖来引入数据校验功能。 在代码中,我们可以使用javax.validation.constraints包中的注解来对数据进行校验。常用的注解包括@NotNull、@NotEmpty、@Size、@Min、@Max等。例如,使用@NotNull注解来标记一个字段不能为空。 首先,在需要校验的类中,添加注解@Validated,这样Spring Boot会自动校验被注解标记的字段。然后,在需要校验的字段上添加相关的校验注解,如@NotNull。最后,在Controller的方法参数上添加@Valid注解,来触发数据校验。 下面是一个示例代码,展示了如何在Spring Boot中进行数据校验。 ```java import org.springframework.validation.annotation.Validated; import javax.validation.constraints.NotNull; @RestController @Validated public class UserController { @PostMapping("/user") public String addUser(@Valid @RequestBody User user) { // 业务逻辑处理 // ... return "User added successfully"; } public class User { @NotNull private String username; // getters and setters } } ``` 在上述示例中,我们定义了一个UserController类,其中的addUser方法用于添加用户。在User类中,我们使用了@NotNull注解来标记username字段不能为空。在addUser方法的参数中,我们使用了@Valid注解来触发数据校验。 通过以上配置,当我们发送一个POST请求到"/user"的时候,Spring Boot会自动校验请求体中的数据。如果校验失败,会返回相应的错误信息。如果校验通过,会执行业务逻辑并返回成功信息。 总结一下,Spring Boot提供了简单易用的数据校验功能,可以通过注解方式实现。通过添加相应的依赖和配置,我们可以在项目中方便地使用数据校验功能,保证数据的有效性和完整性。 :https://www.jianshu.com/p/2dabf4f0b72e :https://www.baeldung.com/spring-boot-bean-validation
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ꦿ๑簡單點๑

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

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

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

打赏作者

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

抵扣说明:

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

余额充值