springboot 参数校验使用

1. 引用校验jar包

<dependency>
    <groupId>org.springframework.bootgroupId>
    <artifactId>spring-boot-starter-validationartifactId>

dependency>

2. 接收参数的Vo类引用

@Data
public class DemoVo {
     
    @NotNull(message = "demo 的 ID 参数有误")
    private Integer id;
    @NotBlank(message = "名称不能为空")
    private String name;
    @Valid
    @NotNull(message = "至少有一个用户")
    private List<UserVo> userVoList;
}

需要校验当前实例内部属性时,需要使用@Valid注解标记。

3. 在Controller中使用

@ApiOperation("测试运行")
@PostMapping("/demo")
public String test(@Validated @RequestBody DemoVo demoVo) {
System.out.println(JSON.toJSONString(demoVo));
return JSON.toJSONString(demoVo);
}

在参数的注解前加上spring的@Validated注解或者javax的@Valid注解,@RequestBody注解是Post请求专用,get请求也能使用校验,但是不能带@RequestBody注解,而且路径上的参数需要单独接收,

@GetMapping("/get-demo/{id}")
public String testGet( @PathVariable("id") int id,@Valid UserVo userVo)

在get请求体中的参数同样能使用对应的校验规则。

4. 定义校验结果的异常处理类

@RestControllerAdvice
@Order(-999)
public class ParamExceptionHandler {
     
    /**
     * post参数校验返回的异常
     * @param ex post参数校验异常
     * @return ResultDto
     */
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public ResultDto exceptionHandler(MethodArgumentNotValidException ex) {
     
        return getResultDto(ex.getBindingResult());
    }

    private ResultDto getResultDto(BindingResult bindingResult) {
     
        List<ObjectError> errorList = bindingResult.getAllErrors();
        if (CollectionUtils.isEmpty(errorList)) {
     
            return new ResultDto(ErrorCode.SYSTEM_ERROR);
        }
        ObjectError objectError = errorList.get(0);
        String field;
        if (objectError instanceof FieldError) {
     
            FieldError fieldError = (FieldError) objectError;
            field = fieldError.getField();
        } else {
     
            field = objectError.getObjectName();
        }
        String eMsg = objectError.getDefaultMessage();
        return new ResultDto(ErrorCode.PARAM_ERROR, field, eMsg);
    }

    /**
     * get请求参数校验返回的异常
     * @param ex get请求参数校验异常
     * @return ResultDto
     */
    @ExceptionHandler(BindException.class)
    public ResultDto exceptionHandler(BindException ex) {
     
        return getResultDto(ex.getBindingResult());
    }
}

这里建议自定义一个返回结果类ResultDto,定义一个结果码枚举类ErrorCode。

5. 关闭springboot的自动处理异常

#出现错误时, 直接抛出异常
spring.mvc.throw-exception-if-no-handler-found=true

6. swagger页面异常无法使用

步骤五之后莫名其妙的swagger就无法打开了,网上查询得到的原因是步骤五配置后DispatcherServlet只会直接匹配对应路径的Controller,所以需要把相应的路径配置指定的资源:

@Configuration
public class BaoYongMvcConfigurationSupport extends WebMvcConfigurationSupport {
     
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
     
        registry.addResourceHandler("/**").addResourceLocations(
                "classpath:/static/");
        registry.addResourceHandler("swagger-ui.html").addResourceLocations(
                "classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**").addResourceLocations(
                "classpath:/META-INF/resources/webjars/");
        super.addResourceHandlers(registry);
    }
}

你可能感兴趣的:(java组件使用,spring,boot,swagger)