对于写Java的程序员来说,不管是写单纯的接口、还是页面后台一把梭,后端参数校验的功能都是整个代码不可或缺的一部分,它可以从系统入口过滤掉一些不合法的数据,以确保我们的系统稳定。

还记得我刚入行Java写后端那会儿,因为刚从Android端转后端开发,对对端开发还不是很熟悉。有天我们架构师老大给了我一个需求、要写一个接口给客户端调用,功能其实挺简单:就是根据客户端传过来的一些参数去数据库查数据,再返回给客户端。

我虽然作为一个后端萌新,但毕竟写代码的底子还在啊!很快我就完成了,自己测试一下完美通过,立刻提交代码、并主动叫我们老大Code review,我心里还指着我们老大能夸我一顿、说我写得真快呢!

没想到我们老大只看了一眼就把我提交的代码打回来了,我记得当时我的代码差不多是这样写的:

我自问写的代码没问题,就找老大问他我的代码没问题怎么给我打回来了?只见老大一脸无奈地看着我说:功能是没问题,就是写的太丑陋了点。好吧,我承认代码写的是长了点、乱了点,可那是因为接口参数太多,不得一个个校验一下吗?

说到这里,老大微微一笑说:来,教你一招。只见老大手指上下翻飞,三两下就我的校验参数地代码全删完了,重构完地代码瞬间清爽了许多:

老大得意的对我说:看起来不错吧?不要你晚上加个班熟悉一下Spring Validation机制吧?宝宝心里苦啊!

下面我们就一起来看看Spring Validation怎么使用吧。

首先添加POM依赖

新建一个Spring Boot项目,并在pom.xml文件添加依赖:

需要特别注意的一点是:如果我们项目中引入了spring-boot-starter-web依赖,那么它会自动依赖spring-boot-starter-validation,无需我们再手动添加依赖,防止出现一些版本兼容的问题。

添加约束注解

在接收参数的UserReq实体类对应的属性上加上约束注解:

注意点:每个约束注解都有一个message元素,用于校验失败时的提示信息

一个属性可以添加多个约束注解,所有注解是与的关系,必须全部验证通过

可以使用正则表达式校验参数

眼尖的同学可能会发现上面代码中用到的一些约束注解一些是引用自javax.validation.constraints包下,还有一些引用自org.hibernate.validator.constraints包下,这是怎么一回事呢?

说到这里,不得不提一下JSR-303,JSR-303是JAVA EE(现改名为:Jakarta EE)中的一项子规范,叫Bean Validation,它定义了一些实体和方法验证的约束和接口规范,而Hibernate Validator对Bean Validation规范中所有内置约束注解都提供了实现,并且还添加了一些额外的约束注解。

Bean Validation中内置的约束注解:

Hibernate Validator中添加的约束注解:

值得一提的是:在Hibernate Validator中额外添加的一些优秀的约束注解比如@Email、@NotEmpty、@NotBlank已经被吸收到Bean Validation标准约束注解中,所有我们在代码中Import时应尽量使用javax.validation.constraints包下的约束注解。

怎么使用呢?

接收参数的实体类我们已经改造好了,但是还不能实现校验的功能,还需要对Controller进行改造:

在接收方法的参数前面加上@Validated注解,当然也可以加@Valid注解想要获取参数校验的结果,则需要进行校验的参数后面紧跟一个BingingResult类型的参数,用来绑定校验结果

关于第一点,@Validated注解由Spring框架提供,可以说是对JSR-303规范标准注解@Valid的封装,可以提供额外的例如分组校验的功能。实际上任何以"Valid"开头的注解都可以实现同样的效果(至于原因有机会专门写一篇讲一下,感兴趣的可以关注一下)

至于第二点,为什么校验结果会自动绑定到后面紧跟的BingingResult对象,这里面涉及到Spring DataBinder数据绑定相关的知识(以后会专门讲解,感兴趣的可以关注一下),现在我们只需要知道这样写就行。

请求测试

现在我们使用Postman工具来请求我们的接口:

然后我们打上断点来调试一下bindingResult对象:

可以看到bindingResult对象成功绑定并返回了三个属性校验失败的结果。

分组校验

我们写业务时通常会存在一种情况:新增操作时通常不需要校验参数Id,而在修改或删除操作时我们又需要校验参数Id,那么对于同一个参数接收类UserReq,我们要怎么处理呢?

很简单,首先我们新建一个更新分组,只需要一个普普通通的接口类就行:

接着我们在UserReq类里新增一个id属性,同时加上@NotNull分组校验:

groups支持传入一个数组,可以传入多个分组,对于id属性来说,在更新和删除操作时我们都需要校验该属性。

最后,在Controller里更新接口方法中添加校验分组:

我们只需要在注解中加上需要校验的Update分组就行啦。

java校验参数防止攻击_程序员写接口参数校验,总是太多if else?一招让你避免体力活...相关推荐

  1. java 字符串转骆驼命名_程序员必知的Java基础:5条命名规范和8种数据类型归纳...

    原标题:程序员必知的Java基础:5条命名规范和8种数据类型归纳 一.Java命名规范 任何一种语言都有一套针对于语言自身的命名的规范,java也不例外.接下来,我就列举一下java对命名的规范. 下 ...

  2. java c++ python哪个好_程序员学java好还是python语言好 c++又如何

    技术程序员学Java.C++.Python... 分析对比,到底学什么语言吃香,哪种语言最靠谱,如何学好这些语言呢? 几天前,我们在知识上看到这样一个问题:"java,C++,Python, ...

  3. java中dom是什么_程序员总说的DOM到底是什么?

    大家好,有些词儿,程序员之间虽然天天说,彼此之间心照不宣,但是在面对一些非技术的产品同学的时候,对方却不一定能一下子就get到点.这个系列的文章就是为了解决这种尴尬的,理想的效果是,只要一提起这些词儿 ...

  4. java是高级还是低级语言_程序员:高级与低级编程语言,您应该学习哪些内容?...

    当你试图找出要学习的编程语言时,你可能会遇到高级和低级的术语.人们一直在谈论高级和低级编程语言. 高级和低级编程语言 在整篇文章中,我将讨论"高级"和"低级"语 ...

  5. 程序员吃饭段子Java吃完就走_程序员专用段子笑话,笑话死循环

    1 IT人表示屁股上还得纹一个, 要不中间来个hello world! 2 真正的程序员喜欢兼卖爆米花,他们利用CPU散发出的热量做爆米花,可以根据米花爆裂的速度听出正在运行什么程序. 3 十年生死两 ...

  6. java相关的数学知识_程序员必备的一些数学基础知识

    作为一个标准的程序员,应该有一些基本的数学素养,尤其现在很多人在学习人工智能相关知识,想抓住一波人工智能的机会.很多程序员可能连这样一些基础的数学问题都回答不上来. 矩阵A(m,n)与矩阵B(n,k) ...

  7. java编程用什么笔记本_程序员都用什么牌子的笔记本,你知道吗?

    在看电脑之前,我们可能需要先考虑使用什么操作系统.(虽说可以装虚拟机,但性能毕竟不一样) 根据今年某网站进行的调查显示: 99%的程序员会选择三大主流操作系统,也就是windows.macOS.Uni ...

  8. 一个Java工程师的自我修养_程序员自我修养

    毕业N年,每个人在能力跑道上,有了或大或小的差距.有些人一直在重复的劳动,有些人却能从中总结和解决问题.通过成长日活动,我们或许可以探讨下,怎样共同成长.共同前行,跟"勤奋战术掩盖下的战略懒 ...

  9. Java如何接手别人项目_程序员必备技能——怎样快速接手一个项目

    作为一个程序员,我们很少能从头到尾参与一个新项目的开发.如果你经常开发的是新项目,那你真是太幸福了. 更多的情况是半路进入一个项目组进行开发,或者是有其他同事离职了,之前由他维护的系统转交给你维护. ...

最新文章

  1. 安装配置Kali虚拟机----linux----kali
  2. lvs+keepalived实现双实例【双主模型】
  3. 1055 The World‘s Richest (25 分)【难度: 一般 / 知识点: 多关键字排序】
  4. ArcGIS几种数据格式2
  5. iOS AVAudioPlayer和AVAudioPlayerDelegate-音频播放处理中断
  6. uboot 的 bootcmd 和bootargs参数详解
  7. 华为GaussDB相比PostgreSQL做了哪些内核优化?
  8. 一个人学的软件测试,到底有多难?
  9. 基于android的电影售票APP,基于Android的在线电影售票系统.doc
  10. html页面嵌入高德地图,高德地图WEB版基础控件展示
  11. ipad iphone开发_如何通过Chromecast观看iPhone / iPad视频?
  12. trackmaker翻译_体育翻译滑雪中英对照翻译
  13. ubuntu 14.04 安装搜狗拼音输入法
  14. 游戏引擎Flax Engine分析(八)渲染
  15. MyExcel 3.9.8 版本发布
  16. php邮箱失效链接,wordpress邮件功能设置及密码重置链接失效问题解决
  17. 谷歌浏览器打包扩展程序(记录扩展程序根目录)
  18. 03_深度学习实现手写数字识别(python)
  19. halcon绘制多边形轮廓的方法
  20. 索引的概念,何时加索引?

热门文章

  1. c防止随机数重复_铝及铝模板等焊接常见缺陷、和防止措施12招
  2. java安全密钥_Java安全性:密钥大小或默认参数非法?
  3. php 微信支付退款接口开发,微信支付退款功能开发
  4. android 仿qq 功能,Android 仿QQ界面的实现
  5. as it exceeds the max of 500KB._我的英雄学院The “Ultra” Stage角色介绍第三弹!
  6. RMAN 目录管理维护
  7. git学习3--关联不同的网址的远程分支
  8. 基于JAVA+Servlet+JSP+MYSQL的银行账户管理系统
  9. 基于JAVA+SpringMVC+Mybatis+MYSQL的房屋租赁管理系统
  10. 页面显示pdf_PDF怎样合并?在Mac上合并PDF文件的最佳方法