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

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

上一篇文章讲了多种接受参数的方法 【快学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;

复制代码

测试

2fe98213e70c0e90ffff13a03ab8c3e9.png

644386b4971ab08f7827e4420f8b824a.png

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

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

@NotBlank(message = "username不可为空")

private String username;

复制代码

c3e48c931c3d649c1fc3bcde9065e5b5.png

Length字符串长度判断

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

@Length(min = 2,max = 3)

@NotBlank(message = "username不可为空")

private String username;

复制代码

15d66a2f87ffb6e0934d3a48c6fd2702.png

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

NotNull 限制属性不可谓null

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

范围判断Min和Max

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

@Min(1)

@Max(100)

private Integer age;

复制代码

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

e910723bde16eb9502da9e03e9d8d2bf.png

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

@Min(1)

@Max(100)

@NotNull

private Integer age;

复制代码

3f537b4e28c96088341a2963b41f7347.png

7bc1411146b776d8bedc700789042267.png

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

@Range(min = 1, max = 100)

复制代码

Email 注解校验邮件

@Email

private String email;

复制代码

dc3885ddd566296490fbd9a195e7955e.png

Pattern 注解校验正则表达式

@Pattern(regexp = "\d{4}-\d{2}-\d{2}")

private String birthday;

复制代码

048b4951b87768d80163501e85b20206.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值