首页 > 其他分享 >SpringMVC使用@Valid注解实现数据验证

SpringMVC使用@Valid注解实现数据验证

时间:2023-10-05 10:00:29浏览次数:42  
标签:String 验证 SpringMVC value Valid 注解

一、@Valid 注解的作用

  @Valid 注解是 javax.validation 包中的一个注解,它可以用来标注需要验证的数据对象。当一个带有 @Valid 注解的对象传递给 SpringMVC 的控制器方法时,SpringMVC 会自动调用验证器来验证这个对象。

二、数据验证的流程

SpringMVC 中的数据验证流程如下:

  1. 客户端发起请求。
  2. DispatcherServlet 接收到请求后,根据请求的 URL 映射到对应的 Controller。
  3. Controller 中的方法接收到请求后,如果有需要验证的数据,就使用 @Valid 注解进行标注。
  4. 如果数据验证失败,会抛出 MethodArgumentNotValidException 异常,SpringMVC 会自动将错误信息封装成 JSON 格式返回给客户端。
  5. 如果数据验证通过,Controller 方法会继续执行。

三、如何使用 @Valid 注解

  在 SpringMVC 中,我们可以在 Controller 方法的参数中使用 @Valid 注解来标注需要验证的数据对象。例如:

@RequestMapping("/user")
public String addUser(@Valid User user, BindingResult result) {
    if (result.hasErrors()) {
        // 处理验证失败的情况
    }
    // 处理验证成功的情况
}

  在上面的例子中,我们使用 @Valid 注解标注了 User 对象,当这个对象传递给 addUser 方法时,SpringMVC 会自动调用验证器来验证这个对象。验证结果会被封装成一个 BindingResult 对象,我们可以通过它来获取验证结果。

四、数据验证的规则

  在使用 @Valid 注解进行数据验证时,我们需要定义验证规则。验证规则可以通过在对应的数据对象中添加 javax.validation.constraints 包中的注解来实现。例如,我们可以在 User 类中添加如下注解:

public class User {
    @NotNull(message = "用户名不能为空")
    private String username;
    @Size(min = 6, max = 20, message = "密码长度必须在 6 到 20 个字符之间")
    private String password;
    @Email(message = "邮箱格式不正确")
    private String email;
    // 省略 getter 和 setter 方法
}

  在上面的例子中,我们使用 @NotNull、@Size 和 @Email 注解来定义了用户名、密码和邮箱的验证规则。如果这些规则被违反了,验证器会自动将错误信息封装成 BindingResult 对象返回给客户端。

五、自定义验证规则

  除了使用 javax.validation.constraints 包中的注解来定义验证规则外,我们还可以自定义验证规则。自定义验证规则需要实现 ConstraintValidator 接口,例如:

public class CheckCaseValidator implements ConstraintValidator<CheckCase, String> {
    private CaseMode caseMode;
    @Override
    public void initialize(CheckCase constraintAnnotation) {
        this.caseMode = constraintAnnotation.value();
    }
    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        if (value == null) {
            return true;
        }
        if (caseMode == CaseMode.UPPER) {
            return value.equals(value.toUpperCase());
        } else {
            return value.equals(value.toLowerCase());
        }
    }
}

  在上面的例子中,我们实现了一个 CheckCaseValidator 验证器,它可以用来验证一个字符串是否全是大写或全是小写。这个验证器需要使用 @CheckCase 注解来标注,例如:

public class User {
    @CheckCase(CaseMode.UPPER)
    private String name;
    // 省略 getter 和 setter 方法
}

  

标签:String,验证,SpringMVC,value,Valid,注解
From: https://www.cnblogs.com/visioning/p/17743099.html

相关文章

  • SpringMVC拦截器
     1.拦截器接口 2.工作流程 3.配置拦截器1<!--配置拦截器(可多个)-->2<mvc:interceptors>3<mvc:interceptor>4<!--设置拦截器要拦截的url地址-->5<mvc:mappingpath="/user/**"/>6<!--设置拦截器不拦截的url地址-->7......
  • SpringMVC异常处理
     @ControllerAdvice没有切点只有增强1.全局统一异常处理类1packagecom.cn.globalexpction;23importorg.springframework.ui.ModelMap;4importorg.springframework.web.bind.annotation.ControllerAdvice;5importorg.springframework.web.bind.annotation.......
  • SpringMVC resultful架构风格
     <inputtype="hidden"name="_method"value="DELETE"/>  1.RestfulController.java 1packagecom.cn.restful;23importorg.springframework.stereotype.Controller;4importorg.springframework.ui.ModelMap;5......
  • @PathVariable注解
    @PathVariable主要作用:映射URL绑定的占位符带占位符的URL是Spring3.0新增的功能,URL中的{xxx}占位符可以通过@PathVariable(“xxx”)绑定到操作方法的入参中。例如:@RequestMapping("/user/{id}")publicStringtestPathVariable(@PathVariable("id")Stringid){System.o......
  • 手动开发-实现SpringMVC底层机制--小试牛刀
    在这里说的底层机制的实现主要是指:前端控制器、Controller、Service注入容器、对象自动装配、控制器方法获取参数、视图解析、返回json数据。前端控制器前端控制器就是核心控制器。在这里我们可以设计一个Servlet来充当核心控制器:LingDispatcherServlet.java.这个控制器的作用......
  • 手动开发-简单的Spring基于注解配置的程序--源码解析
    在前文中《手动开发-简单的Spring基于XML配置的程序--源码解析》,我们是从XML配置文件中去读取bean对象信息,再在自己设计的容器中进行初始化,属性注入,最后通过getBean()方法进行返回。这篇文章,我们将基于注解的视角,实现简单的Spring容器。在这里我们还将做一些改动,前文我们是通过xml......
  • Mybatis查询报错 foreach 子查询 (invalid comparison)
    Mybatis查询报错invalidcomparison:java.lang.Stringand[Ljava.lang.String;原因去掉黄色部分<iftest="null!=businessTypeand''!=businessType">  andt.businessTypein     <foreachcollection="businessType"......
  • MyBatis 注解写 SQL 判断空字符串 或 判断为空
    XXXXMapper接口:这里判断数据不能为空@Select("<script>" +"select*fromgs_store" +"<where>" +" <iftest='storeTel!=null'>" +" andstore_tel=#{storeTel}" +" <......
  • Metadata.allowExtensions 注解的一个实际使用例子
    @UI注解随着SAP标准的FioriElements应用一起发布。如果SAP发布的标准CDSview包含了@Metadata.allowExtensions:true的注解,意味着Partner或者其他IndustrySolution可以通过Extensionview的方式来override标准CDSview里的annotation,前提是这些Extensio......
  • springMVC自定义校验注解
     1.定义注解校验器PhoneNoValidator.java1/**2*@Authorhxy3*@Description4*@Date2023/9/1410:485*@Version1.06*/7publicclassPhoneNoValidatorimplementsConstraintValidator<PhoneNo,String>{8@Override9publicvo......