浅谈spring方法级参数校验(@Validated)

作者:Leonarde_WP 时间:2021-06-25 00:43:25 

依赖的jar包:

spring相关jar包版本:4.3.1.RELEASE


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

一、配置与注入 MethodValidationPostProcessor

注意:spring容器与springMVC容器需要各配置一个,呵呵,大家还是用springBoot吧


<!--注册方法验证的处理器-->
<bean class="org.springframework.validation.beanvalidation.MethodValidationPostProcessor"/>

二、需要在验证的类上(最好在接口上)添加注解 @Validated

例子:


@RequestMapping("/add")
public void add(@Validated CoverageAddDTO coverageAddDTO, HttpServletResponse response) {
 String validateTip = validateParams(coverageAddDTO);
 if (StringUtils.isNotBlank(validateTip)) {
   ajaxJsonErrorMessage(response, validateTip);
   return;
 }
 BaseBO dealResult = coverService.addProjectInfo(coverageAddDTO);
 if (dealResult.getHandleSuccess()) {
   ajaxJsonSuccessMessage(response, "新增成功");
 } else {
   ajaxJsonErrorMessage(response, dealResult.getMessage());
 }
}

class CoverageAddDTO {
 /**
  * 唯一键,项目唯一标识(一般是项目名称)
  */
 @NotBlank(message = "重要参数不能为空")
 private String sessionId;

/**
  * 项目的Git地址
  */
 @NotBlank(message = "重要参数不能为空")
 @Pattern(regexp = "^git@.*\\.git$", message = "Git地址不符合规范(git@....git)")
 private String gitUrl;

/**
  * Git上分支名称
  */
 @NotBlank(message = "重要参数不能为空")
 private String branchName;

或者


/**
* @description: jedis操作redis集群-接口方法类
* @author: wangpeng
**/
@Validated
public interface JedisClient {

/**
  * 设置一个字符串类型的值,如果记录存在则覆盖原有value
  *
  * @param key   值对应的键
  * @param value 值
  * @return 状态码, 成功则返回OK
  */
 String set(@NotBlank(message = "key值不能为空") String key, String value, @Min(1) int expireSeconds);

三、捕获 ConstraintViolationException 异常,进行后续提示等处理


@ControllerAdvice
public class GlobalExceptionHandler {
 private static final Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);
 /**
  * 处理接口数据验证异常
  */
 @ExceptionHandler(ConstraintViolationException.class)
 @ResponseBody
 public String handleMethodArgumentNotValidException(ConstraintViolationException ex) {
   logger.error("ConstraintViolationException:{}", ex.getMessage());
   Iterator<ConstraintViolation<?>>
       iterator = ex.getConstraintViolations().iterator();
   String message = null;
   if (iterator.hasNext()) {
     message = iterator.next().getMessage();
   }
   return encode(message);
 }

/**
  * 处理接口数据验证异常
  */
 @ExceptionHandler(BindException.class)
 @ResponseBody
 public String handleMethodArgumentNotValidException(BindException ex) {
   logger.error("BindException:{}", ex.getMessage());
   String message = ex.getFieldErrors().get(0).getDefaultMessage();
   return encode(message);
 }

@ExceptionHandler(Exception.class)   // 捕获所有逃逸的异常
 @ResponseBody
 public String handleAllUnCatchException(Exception ex) {
   logger.error("未知异常:", ex);
   String message = ex.getMessage();
   return encode(message);
 }

// 对返回数据进行截取和编码处理,防止中文乱码和返回数据量过大
 private String encode(String errorMsg) {
   String rtnMessage = errorMsg;
   if (StringUtils.isBlank(errorMsg)) {
     rtnMessage = "{\"message\":\"error\",\"status\":\"error\"}";
     return rtnMessage;
   } else {
     if (errorMsg.length() > 100) {
       rtnMessage = errorMsg.substring(0, 100);
     }
     // 特殊字符编码,解决中文乱码问题
     try {
       rtnMessage = URLEncoder.encode(rtnMessage, "UTF-8");
     } catch (UnsupportedEncodingException e) {
       logger.error("URLEncoder报错:", e);
     }
     rtnMessage = "{\"message\":\"" + rtnMessage + "\",\"status\":\"error\"}";
     return rtnMessage;
   }
 }
}

四、支持的注解如下:

spring支持jsr303以及hibernate中的校验规则

@AssertFalse 对应参数为false

@AssertTrue 对应参数为true

@DecimalMax("1") 对应小数的最大值

@DecimalMin("1") 对应小数的最小值

@Digits(integer=1,fraction = 2) 对应数字整数(integer)和小数(fraction)位数

@Future Date只接受将来的时间

@Past Date只接受过去的时间

@Max(100) 数字最大值

@Min(100) 数字最小值

@NotNull 不接受Null值

@Null 只接受Null值

@Pattern(regexp="^a$") 正则表达式regexp为表达式

@Size(min=1,max=2) 参数的长度min/max为最小/最大长度

hibernate validation

@CreditCardNumber Luhn算法校验,用于防止用户错误输入,并不真实校验信用卡号

@EAN 欧洲商品标码校验

@Email 邮箱校验

@Length 校验string的长度

@LuhnCheck Luhn算法校验

@NotBlank 字符串非null非空

@NotEmpty 字符串、集合、map非空

@ParameterScriptAssert 使用脚本进行校验支持JSR223脚本

@Range 匹配数字或表示数字的字符串的取值范围

@SafeHtml 校验是否包含恶意脚本

@URL 合法URL

@Validated校验的坑

浅谈spring方法级参数校验(@Validated)

BindingResult必须紧挨着放在实体的后面,否则跳转后

浅谈spring方法级参数校验(@Validated)

来源:https://blog.csdn.net/wangpeng322/article/details/81237886

标签:spring,参数,校验,@Validated
0
投稿

猜你喜欢

  • android开发教程之清除android数据缓存示例(清除本地数据缓存)

    2021-10-14 16:11:42
  • springboot FeignClient注解及参数

    2021-07-09 21:59:07
  • Spring Bean自动装配入门到精通

    2023-11-03 07:29:09
  • 解析Android开发优化之:对界面UI的优化详解(一)

    2023-05-23 17:45:10
  • Android三种方式实现ProgressBar自定义圆形进度条

    2021-09-15 11:19:43
  • Java深入了解数据结构之二叉搜索树增 插 删 创详解

    2023-02-14 08:08:00
  • Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法

    2023-11-19 00:24:05
  • java使用Jdom实现xml文件写入操作实例

    2022-09-30 02:38:23
  • Java中的Gradle与Groovy的区别及存在的关系

    2023-05-13 17:28:46
  • JAVA 格式化日期、时间的方法

    2023-10-17 07:53:22
  • Java运算符从见过到掌握上

    2022-09-08 02:12:43
  • Android自定义View之绘制圆形头像功能

    2022-09-27 19:24:29
  • java IO流 之 输入流 InputString()的使用

    2023-08-22 07:44:31
  • 详解如何热更新线上的Java服务器代码

    2021-05-26 01:29:33
  • Android使用OkHttp发送post请求

    2022-12-04 13:24:57
  • springboot 按月分表的实现方式

    2023-11-25 00:03:47
  • JAVA字符串占位符使用方法实例

    2021-09-20 17:30:27
  • 在Java的Struts中判断是否调用AJAX及用拦截 器对其优化

    2023-11-25 00:40:40
  • springboot基于Mybatis mysql实现读写分离

    2023-11-27 21:42:59
  • Java实现飞机航班管理系统的思路详解

    2022-08-20 19:48:42
  • asp之家 软件编程 m.aspxhome.com