SpringBoot ~ 数据校验

简介: SpringBoot数据校验 添加pom依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </d...
+关注继续查看

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=内容长度过短

    1563358182687

  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;
          }
      }
目录
相关文章
|
2月前
|
存储 JSON 关系型数据库
深入探索MySQL中JSON数据的查询、转换及springboot中的应用
MySQL版本引入了对JSON数据类型的支持,这为我们处理和存储非结构化数据提供了新的可能性。通过灵活利用MySQL的JSON函数,我们可以实现高效的查询和转换操作,提取有用的数据,并将其转换为有意义的格式。本文将深入探索MySQL中JSON数据的查询与转换技巧,帮助您更好地利用这一功能。
231 0
深入探索MySQL中JSON数据的查询、转换及springboot中的应用
|
4月前
|
SQL 数据库
springboot+mybatis,mapper调用查询的数据为空,报空指针异常
springboot+mybatis,mapper调用查询的数据为空,报空指针异常
292 0
|
4月前
|
XML JSON 人工智能
springboot工程中调用第三方接口json数据定时存入数据库
springboot工程中调用第三方接口json数据定时存入数据库
|
4月前
|
JSON 前端开发 数据格式
【springboot+vue前后端分离】之后台接收不到前台的数据
【springboot+vue前后端分离】之后台接收不到前台的数据
|
4月前
|
前端开发 Java 应用服务中间件
IDEA+springboot部署前端项目无法访问数据404问题
IDEA+springboot部署前端项目无法访问数据404问题
95 0
|
5月前
|
canal 消息中间件 网络协议
Java:SpringBoot整合Canal+RabbitMQ组合实现MySQL数据监听
Java:SpringBoot整合Canal+RabbitMQ组合实现MySQL数据监听
310 0
|
5月前
|
Java 关系型数据库 MySQL
java入门019~springboot批量导入excel数据到mysql
java入门019~springboot批量导入excel数据到mysql
108 0
|
5月前
|
缓存 Java
SpringBoot程序数据预装载
在项目实际的开发过程中,有时候会遇到需要在应用程序启动完毕对外提供服务之前预先将部分数据装载到缓存的需求。本文就总结了常见的数据预装载方式及其实践。
49 0
|
5月前
|
JSON 前端开发 Java
基于Springboot外卖系统16:菜品修改模块+菜品信息回显+ID查询口味列表+组装数据并返回
在菜品管理列表页面点击修改按钮,跳转到修改菜品页面,在修改页面回显菜品相关信息并进行修改,最后点击确定按钮完成修改操作。
57 0
|
Java 网络架构
第十二篇:SpringBoot 2.x数据校验
介绍 在项目的过程中,对于参数的校验是必须的,如果参数比较少的话我们可以直接通过代码进行校验,但是数据较大时再用这个方法就比较笨重了,接下来就该我们的主角Validation闪亮登场了 pom.
2040 0
相关产品
云迁移中心
推荐文章
更多