博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【快学springboot】4.接口参数校验
阅读量:7078 次
发布时间:2019-06-28

本文共 1655 字,大约阅读时间需要 5 分钟。

前言

在开发接口的时候,参数校验是必不可少的。参数的类型,长度等规则,在开发初期都应该由产品经理或者技术负责人等来约定。如果不对入参做校验,很有可能会因为一些不合法的参数而导致系统出现异常。

上一篇文章讲了多种接受参数的方法。因为目前json类型的参数是最常用的,所以这里只讲解json类型的参数校验。其他类型的大同小异。

新建一个Param.java

public class Param {  private String username; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; }}复制代码

目前这个类只有一个username属性。

使用Validated注解开启参数校验

@PostMapping(value = "/validate/notblank")public Object validateNotBlank(@RequestBody @Validated Param param) { return param;}复制代码

NotBlank 非空判断

修改Param.java,在username属性上添加NotBlank注解

@NotBlankprivate String username;复制代码

测试

通过控制台,我们可以看到抛出了一个MethodArgumentNotValidException异常,上面的返回结果其实是springboot默认的异常捕获器返回的。为了统一接口的数据返回格式,我们也需要自定义一个全局异常拦截器,这个将会在下一讲中讲解。

我们还可以通过NotBlank注解的message属性设置异常信息:

@NotBlank(message = "username不可为空")private String username;复制代码

Length字符串长度判断

还是那个Param.java,我们给username加上Length注解,如下:

@Length(min = 2,max = 3)@NotBlank(message = "username不可为空")private String username;复制代码

同样,我们也可以使用message属性来设置返回错误信息。这里就不演示了。

NotNull 限制属性不可谓null

虽然前面有NotBlank注解了,但是一些Integer,Long等包装类型,还是需要用到NotNull注解来判断。

范围判断Min和Max

在Param.java上新增一个age属性,并且使用Min和Max注解限定大小

@Min(1)@Max(100)private Integer age;复制代码

这样写的问题是,如果age为空,则不会校验。如下:

所以我们还需要加上NotNull注解

@Min(1)@Max(100)@NotNullprivate Integer age;复制代码

也可使用@Range注解来限定范围

@Range(min = 1, max = 100)复制代码

Email 注解校验邮件

@Emailprivate String email;复制代码

Pattern 注解校验正则表达式

@Pattern(regexp = "\d{4}-\d{2}-\d{2}")private String birthday;复制代码

总结

以上总结了部分常用的参数校验的方法,当然还有很详细的一些没有列举处理,有需要的,可以自行搜索使用方式即可。参数校验,往往需要和全局的异常拦截器来配套使用,使得返回的数据结构永远是保持一致的,这样才能方便客户端解释。

下一节会对统一返回格式和全局异常拦截器做一个讲解。

转载于:https://juejin.im/post/5d05e64e6fb9a07ef56234c4

你可能感兴趣的文章
Leetcode: Arranging Coins
查看>>
简单学习node微信开发
查看>>
EditPlus如何设置保存时不产生.bak备份文件?
查看>>
用ISAPI Filter设置HttpOnly属性
查看>>
Zookeeper的安装部署,zookeeper参数配置说明,集群搭建,查看集群状态
查看>>
为什么说BCH是最安全的数字货币之一?
查看>>
C++/Debug模式查看EFL(标志寄存器)详解
查看>>
我的友情链接
查看>>
oracle体系结构之 DB高速缓存池
查看>>
我的友情链接
查看>>
华为Agile Controller-Campus web界面admin管理员密码不对无法登陆
查看>>
遇到多个构造器参数时要考虑用构建器
查看>>
windos 8 虚拟光驱/硬盘技术
查看>>
WLC和汇聚交换机的配置
查看>>
使用python-gitlab的API V4来批量创建projects
查看>>
CLR.Via第三版第二章 生成、打包、部署和管理i应用程序及类型(
查看>>
关于ha高可用性的安装,ClusterIP和tomcat的配置
查看>>
我的系统我做主-----深度裁剪红帽5.8系统过程演示(只有5M哦)
查看>>
Zend server最大化应用程序的性能、扩展性和可用性
查看>>
Mac OSX操作系统安装和配置Zend Server 6教程(4)
查看>>