【快学springboot】4.接口参数校验

栏目: Java · 发布时间: 4年前

内容简介:在开发接口的时候,参数校验是必不可少的。参数的类型,长度等规则,在开发初期都应该由产品经理或者技术负责人等来约定。如果不对入参做校验,很有可能会因为一些不合法的参数而导致系统出现异常。上一篇文章讲了多种接受参数的方法目前这个类只有一个username属性。

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

上一篇文章讲了多种接受参数的方法 【快学springboot】3.多种接受参数的方式 。因为目前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注解

@NotBlank
private String username;
复制代码

测试

【快学springboot】4.接口参数校验
【快学springboot】4.接口参数校验

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

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

@NotBlank(message = "username不可为空")
private String username;
复制代码
【快学springboot】4.接口参数校验

Length字符串长度判断

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

@Length(min = 2,max = 3)
@NotBlank(message = "username不可为空")
private String username;
复制代码
【快学springboot】4.接口参数校验

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

NotNull 限制属性不可谓null

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

范围判断Min和Max

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

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

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

【快学springboot】4.接口参数校验

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

@Min(1)
@Max(100)
@NotNull
private Integer age;
复制代码
【快学springboot】4.接口参数校验
【快学springboot】4.接口参数校验

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

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

Email 注解校验邮件

@Email
private String email;
复制代码
【快学springboot】4.接口参数校验

Pattern 注解校验正则表达式

@Pattern(regexp = "\d{4}-\d{2}-\d{2}")
private String birthday;
复制代码
【快学springboot】4.接口参数校验

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

P2P网贷投资手册

P2P网贷投资手册

徐红伟 / 同济大学出版社 / 2015-4 / CNY 28.00

《P2P网贷投资手册》由“P2P网络借贷知多少”、“新手如何开始P2P网贷投资”和“如何确定适合自己的网贷投资策略”三部分组成。将网贷之家平台上众多投资人和从业者的智慧集结成册,分享给网贷投资上的同路人。一起来看看 《P2P网贷投资手册》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具