postmapping注解参数说明_不来学一下SpringBoot统一参数校验?

  • 微服务架构之春招总结:SpringCloud、Docker、Dubbo与SpringBoot
  • 一个SpringBoot问题就干趴下了?我却凭着这份PDF文档吊打面试官.
  • 金三银四第一天,啃透这些SpringBoot知识点,还怕干不赢面试官?

前言

  在日常的开发中,参数校验是非常重要的一个环节,严格参数校验会减少很多出bug的概率,增加接口的安全性。也会减少对接时不必要的沟通。比如说:在对接的时候前端动不动就甩个截图过来说接口有问题,你检查了半天发现前端传递的参数有问题。针对以上:今天给大家分享一下SpringBoot如何实现统一参数校验。

01795932ecb5bc818518ae24c462d0d6.png

实现方式

  使用 @Validated注解配合参数校验注解, 比如:@NotEmpty对参数进行校验。然后对抛出的异常ControllerAdvice进行捕获然后调整输出数据。

TestController

@RestControllerpublic class TestController {    /**     * 表单请求     * @param form 请求参数     * @return 响应数据     */    @PostMapping("/formRequest")    public ResultVo formRequest(@Validated RequestForm form){        return ResultVoUtil.success(form);    }    /**     * JSON请求     * @param form 请求参数     * @return 响应数据     */    @PostMapping("/jsonRequest")    public ResultVo jsonRequest(@RequestBody @Validated RequestForm form){        return ResultVoUtil.success(form);    }}

RequestForm

@Datapublic class RequestForm {    @NotEmpty(message = "姓名不能为空")    private String name;    @Min(value = 1 , message = "年龄不能小于1岁")    private Integer age;    @NotEmpty(message = "性别不能为空")    private Integer sex;}

测试结果

请求:http://localhost:8080/formRequest 不传任何参数。

f3dfe4ae1d9a35ab55c4c7fb58074338.png

这个时候SpringBoot已经根据校验注解对参数进行校验了。并且输出了一大堆的错误信息。这个时候前端在对接的时候看到这样的错误信息,反手就是给你截个图告诉你接口有问题。所以这个时候就该使用 ControllerAdvice规范异常返回信息了。

eb152595589edea440867e47a6e35b41.png

ControllerAdvice

@Slf4j@RestControllerAdvicepublic class ControllerAdvice {    /**     * 拦截表单参数校验     */    @ResponseStatus(HttpStatus.OK)    @ExceptionHandler({BindException.class})    public ResultVo bindException(BindException e) {        BindingResult bindingResult = e.getBindingResult();        return ResultVoUtil.error(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());    }    /**     * 拦截JSON参数校验     */    @ResponseStatus(HttpStatus.OK)    @ExceptionHandler(MethodArgumentNotValidException.class)    public ResultVo bindException(MethodArgumentNotValidException e) {        BindingResult bindingResult = e.getBindingResult();        return ResultVoUtil.error(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());    }}

@RestControllerAdvice会将返回的数据以json输出,如果不需要可以使用@ControllerAdvice

以上代码只返回了错误信息。可以根据实际情况进行调整。

54cf60070c3fe17dee7dacb7957c6754.png

这个时候的错误信息就比较友好了,非常明确的指出了缺少参数。

常用校验注解

9ff9315451cdca99b16da6b8ec9bfe52.png
535c44ad26b5e9f2d31986e96b3a3f53.png

案例

@Datapublic class ExampleForm {    @NotEmpty(message = "姓名不能为空")    @Length(min = 1 , max = 10 , message = "名字长度1~10")    private String name;    @Range(min = 1 , max = 99 , message = "年龄范围在1~99岁")    private Integer age;    @Pattern(regexp = "^[1][3,4,5,7,8][0-9]{9}$" , message = "电话号码有误")    private String phone;    @Email(message = "邮箱格式有误")    private String email;    @Valid    @Size(min = 1 ,max =  10 , message = "列表中的元素数量为1~10")    private List requestFormList;    @Future(message = "开始时间必须大于当前时间")    private Date beginTime;}

实现嵌套验证

  在实际的开发中,前台会后台传递一个list,我们不仅要限制每次请求list内的个数,同时还要对list内基本元素的属性值进行校验。这个时候就需要进行嵌套验证了,实现的方式很简单。在list上添加@Vaild就可以实现了。

@Datapublic class JsonRequestForm {    @Vaild    @Size(min = 1 ,max =  10 , message = "列表中的元素数量为1~10")    private List requestFormList;}


作者:不一样的科技宅
原文链接:https://juejin.im/post/5e5fb6ea51882549422ee257

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值