经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » Java相关 » Spring Boot » 查看文章
Spring Boot使用JSR-380进行校验的示例
来源:jb51  时间:2021/3/1 12:56:33  对本文有异议

介绍

JSR-380 是 J2EE 的一个规范,用于校验实体属性,它是 JSR-303 的升级版,在 Spring Boot 中可以基于它优雅实现参数校验。

<!--more-->

示例

在没有使用 JSR-380 之前,我们一般都会将参数校验硬编码在 controller 类中,示例:

  1. public Result add(@RequestBody User user){
  2. if(StringUtils.isBlank(user.getName())){
  3. return Result.error("用户名不能为空");
  4. }
  5. // ...
  6. }

而使用 JSR-380 只需要通过添加对应的注解即可实现校验,示例:

  1. @Data
  2. public class User{
  3. @NotBlank
  4. private String name;
  5. private Integer age;
  6. }
  1. public Result register(@Validated @RequestBody User user){
  2. // ...
  3. }

这样看起来代码是不是清爽了很多,只需要在需要校验的字段上加上对应的校验注解,然后对需要校验的地方加上 @Validated 注解,然后框架就会帮我们完成校验。

通过全局异常自定义错误响应

框架校验失败之后会抛出异常,需要捕获这个异常然后来自定义校验不通过的错误响应,这里直接贴代码,兼容 @RequestBody@ModelAttribute@RequestParam 三种入参的校验:

  1. @ControllerAdvice
  2. public class GlobalExceptionHandler {
  3.  
  4. @ExceptionHandler(value = {MethodArgumentNotValidException.class, BindException.class})
  5. public ResponseEntity<Result> methodArgumentNotValidHandler(HttpServletRequest request, Exception e) {
  6. BindingResult bindingResult;
  7. if (e instanceof MethodArgumentNotValidException) {
  8. //@RequestBody参数校验
  9. bindingResult = ((MethodArgumentNotValidException) e).getBindingResult();
  10. } else {
  11. //@ModelAttribute参数校验
  12. bindingResult = ((BindException) e).getBindingResult();
  13. }
  14. FieldError fieldError = bindingResult.getFieldError();
  15. return ResponseEntity.ok(Result.fail(Result.CODE_PARAMS_INVALID, "[" + fieldError.getField() + "]" + fieldError.getDefaultMessage()));
  16. }
  17.  
  18. //@RequestParam参数校验
  19. @ExceptionHandler(value = {ConstraintViolationException.class, MissingServletRequestParameterException.class})
  20. public ResponseEntity<Result> constraintViolationHandler(Exception e) {
  21. String field;
  22. String msg;
  23. if (e instanceof ConstraintViolationException) {
  24. ConstraintViolation<?> constraintViolation = ((ConstraintViolationException) e).getConstraintViolations().stream().findFirst().get();
  25. List<Path.Node> pathList = StreamSupport.stream(constraintViolation.getPropertyPath().spliterator(), false)
  26. .collect(Collectors.toList());
  27. field = pathList.get(pathList.size() - 1).getName();
  28. msg = constraintViolation.getMessage();
  29. } else {
  30. // 这个不是JSR标准返回的异常,要自定义提示文本
  31. field = ((MissingServletRequestParameterException) e).getParameterName();
  32. msg = "不能为空";
  33. }
  34. return ResponseEntity.ok(Result.fail(Result.CODE_PARAMS_INVALID, "[" + field + "]" + msg));
  35. }
  36. }

然后再访问一下接口,可以看到错误提示已经按自定义的规范显示了:

可以看到都不需要写任何提示文本就可以完成校验和提示,上图的 不能为空 是框架内置的 I18N 国际化支持,每个注解都内置相应的提示模板。

常用校验注解

注解 描述
@NotNull 验证值不为 null
@AssertTrue 验证值为 true
@Size 验证值的长度介于 min 和 max 之间,可应用于 String、Collection、Map 和数组类型
@Min 验证值不小于该值
@Max 验证值不大于该值
@Email 验证字符串是有效的电子邮件地址
@NotEmpty 验证值不为 null 或空,可应用于 String、Collection、Map 和数组类型
@NotBlank 验证字符串不为 null 并且不是空白字符
@Positive 验证数字为正数
@PositiveOrZero 验证数字为正数(包括 0)
@Negative 验证数字为负数
@NegativeOrZero 验证数字为负数(包括 0)
@Past 验证日期值是过去
@PastOrPresent 验证日期值是过去(包括现在)
@Future 验证日期值是未来
@FutureOrPresent 验证日期值是未来(包括现在)

本文完整代码放在 github

Java Bean Validation Basics

JSR-380 规范

到此这篇关于Spring Boot使用JSR-380进行校验的文章就介绍到这了,更多相关Spring Boot使用JSR-380校验内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号