浅谈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校验的坑
BindingResult必须紧挨着放在实体的后面,否则跳转后
来源:https://blog.csdn.net/wangpeng322/article/details/81237886
猜你喜欢
- 前言:最新Servlet 3.0 * 的使用1.pom.xml添加需要使用的依赖<project xmlns="http:/
- java与JSON数据的转换实例详解JSON与JAVA数据的转换(JSON 即 JavaScript Object Natation,它是一
- 本文实例讲述了Android编程使用GestureDetector实现简单手势监听与处理的方法。分享给大家供大家参考,具体如下:添加手势识别
- /// <summary>/// 获取数据缓存/// </summary>/// <param name=&q
- 下面是我自己收集整理的2017年Java岗位的面试题,可以用它来好好准备面试。一、Java基础1. String类为什么是final的。2.
- 一,下载Zookeeper,地址为http://archive.apache.org/dist/zookeeper/,找到你要下载的版本,我
- C# 匿名函数、lambda表达式、Linq查询一、匿名函数的使用匿名函数是一个“内联”语句或表达式
- settings.xml有什么用?如果在Eclipse中使用过Maven插件,想必会有这个经验:配置settings.xml文件的路径。se
- 正常在Java工程中读取某路径下的文件时,可以采用绝对路径和相对路径,绝对路径没什么好说的,相对路径,即相对于当前类的路径。在本地工程和服务
- 摘要:在spring boot中 MVC这部分也有默认自动配置,也就是说我们不用做任何配置,那么也是OK的,这个配置类就是 WebMvcAu
- 背景在实际开发过程中,会遇到需要编写各类打印模板模板的需求,当然这些在WPF开发中更为常见,但是使用XAML写编辑的打印模板又不能直接发送给
- 最近重构了一下我的存档框架。我在这里对实现方法进行简单的解析。注意这里主要演示算法,所以,效率上并不是最佳。一个游戏中,可能有成百上千个物体
- 一.工程文件二.Main.java主函数,实现类package ui;//主函数实现public class Main { &
- springboot启动是通过一个main方法启动的,代码如下@SpringBootApplicationpublic class Appl
- 最近要做动态数据的提交处理,即需要分析提交数据字段定义信息后才能明确对应的具体字段类型,进而做数据类型转换和字段有效性校验,然后做业务处理后
- 对于服务器端开发人员而言,调用第三方接口获取数据,将其“代理”转化并返给客户端几乎是家常便
- RabbitMQ作为AMQP的代表性产品,在项目中大量使用。结合现在主流的spring boot,极大简化了开发过程中所涉及到的消息通信问题
- 一、前言什么是多渠道打包以及多渠道打包可以做什么,这里就不做介绍了,相信看到这篇文章的你已经了解了,多渠道打包的方式比较多,这里我们用Gra
- Java流程控制用户交互Scannerjava.util.Scanner是Java5的新特征,可以通过Scanner类来获取用户的输入基本语
- 问题来源一般来说,一个稍微大些的项目都会有一些依赖的Jar包,而在将项目部署到服务器的过程中,如果没有持续集成环境的话,也就是说服务器不支持