zoukankan      html  css  js  c++  java
  • springmvc参数校验(一)

    使用SpringMVC时配合hibernate-validate进行参数的合法性校验,能节省一定的代码量。

    1.搭建Web工程并引入hibernate-validate依赖

    <dependency>
        <groupId>org.hibernate.validator</groupId>
        <artifactId>hibernate-validator</artifactId>
        <version>6.0.7.Final</version>
    </dependency> 

    Maven依赖传递,自动依赖validation-api、jboss-logging、classmate。

      

    2.使用校验注解标注在属性上(DTO)

        

    *每个注解都有message属性,该属性用于填写校验失败时的异常描述信息,当校验失败时可以获取对应的message属性值。

    复制代码
    public class User {
    
        @NotNull(message="id不能为空!")
        private Integer id;
        
        @NotBlank(message="用户名不能为空!")
    @Size(min=4,max=12,message="用户名的长度在4~12之间!") private String username; @NotBlank(message="密码不能为空!") private String password; @Email(message="非法邮箱!") private String email; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public User() { super(); } }
    复制代码

    3.控制层中使用DTO接收参数并使用@Validated/@Valid注解开启对参数的校验

      *@Validated注解表示开启Spring的校验机制,支持分组校验,声明在入参上。

      *@Valid注解表示开启Hibernate的校验机制,不支持分组校验,声明在入参上。

      *在DTO后面紧跟BindingResult对象(Error也可以),那么当参数不符合时,能通过该对象直接获取不符合校验的message描述信息。

      *若使用了@Validated/@Valid注解开启校验,但DTO后面没有紧跟BindingResult对象,那么当参数不符合时,将直接返回400 Bad Request状态码。 

    复制代码
    @RestController
    public class BaseController {
    
        @RequestMapping("/test")
        public User test(@Validated User user, BindingResult result) {
            if (result.hasErrors()) {
                List<ObjectError> errors = result.getAllErrors();
                for (ObjectError error : errors) {
                    System.out.println(error.getDefaultMessage());
                }
            }
            return user;
        }
    
    }
    复制代码

    演示:

     结果:

    密码不能为空!
    id不能为空!
    用户名的长度在4~12之间!

    *校验的顺序是随机的,因此程序不能依赖校验的顺序去做相关的逻辑处理。

    4.分组校验

    每个校验注解都有group属性用于指定校验所属的组,其值是Class数组,在Controller中使用@Validated注解开启对参数的校验时若指定要进行校验的组,那么只有组相同的属性才会被进行校验(默认全匹配)

    Class<?>[] groups() default { };

    一般定义标识接口作为组资源

    复制代码
    public interface GroupA {
    
    }
    
    public interface GroupB {
    
    }
    复制代码

    使用校验注解标注在属性上并进行分组

    复制代码
    public class User {
    
        @NotNull(message="id不能为空!",groups = {GroupA.class})
        private Integer id;
        
        @NotBlank(message="用户名不能为空!",groups = {GroupB.class})
        @Size(min=4,max=12,message="用户名的长度在4~12之间!")
        private String username;
    
        @NotBlank(message="密码不能为空!")
        private String password;
        
        @Email(message="非法邮箱!")
        private String email;
    
        public Integer getId() {
            return id;
        }
    
        public void setId(Integer id) {
            this.id = id;
        }
    
        public String getUsername() {
            return username;
        }
    
        public void setUsername(String username) {
            this.username = username;
        }
    
        public String getPassword() {
            return password;
        }
    
        public void setPassword(String password) {
            this.password = password;
        }
    
        public String getEmail() {
            return email;
        }
    
        public void setEmail(String email) {
            this.email = email;
        }
    
        public User() {
            super();
        }
    
    }
    复制代码

     Controller中使用@Validated注解开启对参数的校验并指定校验的组,那么只有组相同的属性才会被进行校验(默认全匹配)

    复制代码
    @RestController
    public class BaseController {
    
        @RequestMapping("/test")
        public User test(@Validated(value= {GroupB.class}) User user, BindingResult result) {
            if (result.hasErrors()) {
                List<ObjectError> errors = result.getAllErrors();
                for (ObjectError error : errors) {
                    System.out.println(error.getDefaultMessage());
                }
            }
            return user;
        }
    
    }
    复制代码

    演示:

      

    结果:

    用户名不能为空!

    *后端一般只返回重名等错误描述信息,对于非空、字符长度、手机邮箱合法性校验等由前端进行判断并提示,后端校验不通过时不返回错误描述信息,所以不需要使用BindingResult获取错误描述,当参数不符合时直接返回400 Bad Request请求。

  • 相关阅读:
    C++文件(夹)选择对话框
    BCB中选择文件对话框TOpenDialog过滤后缀名使用方法
    pjlib深入剖析和使用详解
    PJNATH介绍 -- 开源的用于NAT穿透的ICE, STUN和TURN
    STUN, TURN, ICE介绍
    一个boost底下的线程池
    在Windows下编译WebRTC
    FEC(Forward Error Correction)前向纠错 UDPRTP 中使用用于改善无线等网络丢包等问题--转
    FEC之我见四
    FEC之异或运算应用
  • 原文地址:https://www.cnblogs.com/helloworldmybokeyuan/p/11597649.html
Copyright © 2011-2022 走看看