阿粉写了八千多字,只为讲透参数合法性验证
最近很多读者给阿粉留言,说怎么好久没看到我的文章了,这里说一下。
由于公众号不再按时间线排序,所以你会发现有时候能看到几天前的文章,这不是出BUG,是公众号的一次改变。
至于排序的具体标准是啥,阿粉也不太清楚,大概和你打开某个公众号的频率有关。
所以如果你想第一时间收到阿粉的文章,可以点击Java极客技术的的头像,再点右上角三个点,进去设置一下【星标】。
一、介绍
关于参数合法性验证的重要性就不多说了,即使前端对参数做了基本验证以外,后端依然还需要进行验证,以防不合规的数据直接进入后端,严重的甚至会造成系统直接崩溃!
本文结合自己在项目中的实际使用经验,主要以实用为主,对数据合法性验证做一次总结,不了解的朋友可以学习一下,同时可以立马实践到项目上去。
下面我们通过几个示例来演示如何判断参数是否合法,不多说直接开撸!
二、断言验证
对于参数的合法性验证,最初的做法比较简单,自定义一个异常类。
当判断某个参数不合法的时候,直接抛异常!
然后写一个统一异常拦截器,对抛异常的程序进行处理。
这种做法比较直观,如果当前参数既要判断是否为空,又要判断长度是否超过最大长度的时候,代码就显得有点多了!
于是,程序界的大佬想到了一个更加优雅又能节省代码的方式,创建一个断言类工具类,专门用来判断参数的是否合法,如果不合法,就抛异常!
当我们需要对参数进行验证的时候,直接通过这个类就可以完成基本操作,方式如下:
相比上个步骤,当要判断的参数比较多时,代码明显简洁多了!
类似这样的工具类,spring也提供了一个名为Assert的断言工具类,在开发的时候,可以直接使用!

三、注解验证
使用注解对数据进行合法性验证,可以说是 java界一项非常伟大的创新,使用这种方式不仅使的代码变得很简洁,而且阅读起来非常令人赏心悦目!
3.1、依赖包引入
下面我们一起来看看具体的实践方式,以SpringBoot工程为例,如果需要使用注解校验,直接引入spring-boot-starter-web依赖包即可,会自动将注解验证相关的依赖包打入工程!
下面在创建实体类的时候,还会用到lombok插件,因此还需要引入lombok依赖包!
如果是普通的Java工程,引入以下几个依赖包即可!
3.2、注解校验请求对象
紧接着我们来创建一个实体User,用于模拟用户注册时的请求实体对象!
在web层创建一个register()注册接口方法,同时在请求参数上添加@Valid,如下:
最后自定义一个异常全局处理器,用于处理异常消息,如下:
下面我们启动项目,使用postman来测试一把,看看效果如何?
- 测试字段是否为空

- 测试邮箱是否合法

- 测试密码长度是否符合要求

- 测试密码与确认密码是否相同

3.3、注解校验请求参数
上面我们介绍了请求对象的验证方式,那如果直接在方法上对请求参数进行验证是否同样有效呢?
为了眼见为实,下面我们就来模拟在方法上对请求参数进行验证,看看结果如何。
新建一个查询接口query,如下
使用postman请求试一试,默认给userId参数为null,结果如下:

很清晰的看到,query()方法中的参数注解验证无效!
当我们在UserController类上加上@Validated注解!
使用postman请求再试一试,结果如下!

很清晰的看到,注解进行了验证,同时还抛出异常ConstraintViolationException!

@Validated参数作用于类上时,表示告诉Spring可以对方法中请求参数进行校验!
所有在实际开发的时候,我们可以使用@Validated和@Valid注解的组合来对方法中的请求参数和请求对象进行校验!
同时,@Validated和@Valid注解不仅仅只是验证控制器级别,可以验证任何Spring组件,例如Service层方法入参的验证!
3.4、自定义注解验证
默认的情况下,依赖包已经给我们提供了非常多的校验注解,如下!
- JSR提供的校验注解!

- Hibernate Validator提供的校验注解

但是某些情况,例如性别这个参数可能需要我们自己去验证,同时我们也可以自定义一个注解来完成参数的校验,实现方式如下!
新创建一个Sex注解,其中SexValidator类指的是具体的参数验证类
SexValidator类,实现自ConstraintValidator接口
最后在User实体类上加入一个性别参数,使用自定义注解进行校验!
使用postman来请求试一试,结果如下!
- 不传sex参数

很清晰的看到,已经生效!
3.5、手动进行注解校验
某些时候呢,假如有100个类需要用到校验注解,此时我们可能在每个类会加上注解@Validated或者@Valid,再增加100个这样的类,就会造成很多大量的重复工作。
而此时,我们的诉求是想对有校验注解的实体类进行全局参数验证!
解决办法就会用到Validator提供的手动注解校验证工具类,实现方法如下!
- 新建一个注解验证工具类
使用ValidatorUtils工具类,对参数进行验证
执行之后,结果如下!
当然你还可以对ValidatorUtils类进行改造,当有异常信息的时候,直接抛异常!
同时,你还可以通过@Autowired直接注入的方式来获取Validator对象!
3.6、spring 注解校验原理
如果你对springmvc的方法参数解析器(HandlerMethodArgumentResolver)了解的话,就可能会想到参数校验这块肯定是在对应的方法参数解析器里执行的。
直接定位到resolveArgument这个方法,先通过WebDataBinder进行入参属性绑定,然后再进行校验!

validateIfApplicable方法逻辑,会遍历当前参数methodParam所有的注解,如果注解是@Validated或者注解的名字以Valid开头,则使用WebDataBinder对象执行校验逻辑。

方法参数解析器只针对接口请求时入参进行验证,如果想对任何组件中方法进行注解校验,似乎还缺了点什么!
而当需要对一个类中的方法参数使用注解校验时,在类上加上@Validated就是为了告诉Spring去校验方法参数!
底层核心是通过切面代理类并配合MethodValidationPostProcessor这个后置处理器进行处理!

四、总结
参数验证,在开发中使用非常频繁,如何优雅的进行验证,让代码变得更加可读,是业界大佬一直在追求的目标!
本文主要是对自己在项目中的实际使用到参数验证方式加一整理,希望能帮助到各位网友!
五、参考1、SpringMVC源码
2、JavaGuide - 如何在 Spring/Spring Boot 中做参数校验?[1]
3、胡峻峥 - SpringMvc@Validated注解执行原理[2]
参考资料
[1]JavaGuide - 如何在 Spring/Spring Boot中做参数校验?:https://juejin.im/post/5dc8bc745188254e7a155ba0#heading-14[2]胡峻峥 -SpringMvc@Validated注解执行原理:https://www.cnblogs.com/hujunzheng/p/12570921.html
推荐系统
雨林木风 winxp下载 纯净版 永久激活 winxp ghost系统 sp3 系统下载
系统大小:0MB系统类型:WinXP雨林木风在系统方面技术积累雄厚深耕多年,打造了国内重装系统行业知名品牌,雨林木风WindowsXP其系统口碑得到许多人认可,积累了广大的用户群体,是一款稳定流畅的系统,雨林木风 winxp下载 纯净版 永久激活 winxp ghost系统 sp3 系统下载,有需要的朋友速度下载吧。
系统等级:进入下载 >萝卜家园win7纯净版 ghost系统下载 x64 联想电脑专用
系统大小:0MB系统类型:Win7萝卜家园win7纯净版是款非常纯净的win7系统,此版本优化更新了大量的驱动,帮助用户们进行舒适的使用,更加的适合家庭办公的使用,方便用户,有需要的用户们快来下载安装吧。
系统等级:进入下载 >雨林木风xp系统 xp系统纯净版 winXP ghost xp sp3 纯净版系统下载
系统大小:1.01GB系统类型:WinXP雨林木风xp系统 xp系统纯净版 winXP ghost xp sp3 纯净版系统下载,雨林木风WinXP系统技术积累雄厚深耕多年,采用了新的系统功能和硬件驱动,可以更好的发挥系统的性能,优化了系统、驱动对硬件的加速,加固了系统安全策略,运行环境安全可靠稳定。
系统等级:进入下载 >萝卜家园win10企业版 免激活密钥 激活工具 V2023 X64位系统下载
系统大小:0MB系统类型:Win10萝卜家园在系统方面技术积累雄厚深耕多年,打造了国内重装系统行业的萝卜家园品牌,(win10企业版,win10 ghost,win10镜像),萝卜家园win10企业版 免激活密钥 激活工具 ghost镜像 X64位系统下载,其系统口碑得到许多人认可,积累了广大的用户群体,萝卜家园win10纯净版是一款稳定流畅的系统,一直以来都以用户为中心,是由萝卜家园win10团队推出的萝卜家园
系统等级:进入下载 >萝卜家园windows10游戏版 win10游戏专业版 V2023 X64位系统下载
系统大小:0MB系统类型:Win10萝卜家园windows10游戏版 win10游戏专业版 ghost X64位 系统下载,萝卜家园在系统方面技术积累雄厚深耕多年,打造了国内重装系统行业的萝卜家园品牌,其系统口碑得到许多人认可,积累了广大的用户群体,萝卜家园win10纯净版是一款稳定流畅的系统,一直以来都以用户为中心,是由萝卜家园win10团队推出的萝卜家园win10国内镜像版,基于国内用户的习惯,做
系统等级:进入下载 >windows11下载 萝卜家园win11专业版 X64位 V2023官网下载
系统大小:0MB系统类型:Win11萝卜家园在系统方面技术积累雄厚深耕多年,windows11下载 萝卜家园win11专业版 X64位 官网正式版可以更好的发挥系统的性能,优化了系统、驱动对硬件的加速,使得软件在WINDOWS11系统中运行得更加流畅,加固了系统安全策略,WINDOWS11系统在家用办公上跑分表现都是非常优秀,完美的兼容各种硬件和软件,运行环境安全可靠稳定。
系统等级:进入下载 >
相关文章
- 如何解决Windows 11系统中出现的蓝屏错误代码0x0000005问题
- 笔记本电脑一直有滋滋的响声是为什么(笔记本电脑滋滋响解决方法)
- 如何解决锐龙2200g死机蓝屏
- Win8.1本地搜索为什么无法使用
- Win8.1无线网络不稳定/掉线怎么办
- 电脑机箱漏电怎么消除?电脑机箱漏电是哪里的问题?
- 电脑开不了机怎么办?电脑无法开机怎么解决?
- 硬盘双击无法打开的问题该怎么办
- 风行下载速度慢甚至是为0怎么办?风行播放器下载问题及解决方法汇总
- 苹果回应新的iOS恶意软件YiSpector:已在iOS8.4中解决该问题
- 没有路由器怎么连无线 160wifi 解决没有路由器连接无线问题
- 维棠FLV下载视频失败问题汇总及解决方法
- Word2016 出现“此功能看似已中断 并需要修复”问题解决方案(图文)
- Cisco管理的35个常见问题及解答
热门系统
推荐软件
推荐应用
推荐游戏
热门文章
常用系统
- 1番茄花园Windows7 64位 装机旗舰版
- 2Windows11最新纯净版下载 萝卜家园x64位极简版 永久免费 联想笔记本专用下载
- 3番茄花园 Windows10 22H2 64位 低占用专业精简版
- 4深度技术win10专业版激活密钥系统21H2 X64位 V2023下载
- 5windows7旗舰版下载 深度技术最新高级版 ghost镜像 自动激活下载
- 6【家庭/个人】Windows11 23H2 64位 中文家庭版
- 7系统之家win7企业版纯净ghost系统 V2023镜像下载
- 8青苹果系统win7游戏版 激活密钥 官网镜像下载 GHOST v2023
- 9萝卜家园WIN11娱乐版ghost系统 ISO镜像 X64位 V2023下载




















