服务器之家

服务器之家 > 正文

详解Java后端优雅验证参数合法性

时间:2021-08-09 11:09     来源/作者:奋斗的小方

1、首先创建一个测试实体类Person,并携带如上注解,其注解的作用描述在message

  1. package com.clickpaas.pojo;
  2.  
  3. import com.fasterxml.jackson.annotation.JsonFormat;
  4. import lombok.Data;
  5. import org.hibernate.validator.constraints.Length;
  6. import org.hibernate.validator.constraints.Range;
  7.  
  8. import javax.validation.constraints.*;
  9. import java.math.BigDecimal;
  10. import java.util.Date;
  11. import java.util.List;
  12.  
  13. /**
  14. * @author 方延杰
  15. * @version 1.0
  16. * @since 2020/12/10 9:04 下午
  17. */
  18. @Data
  19. public class Person {
  20.  
  21. @Null(message = "death必须为null")
  22. private String death;
  23.  
  24. @AssertTrue(message = "bool必须为true")
  25. private boolean bool;
  26.  
  27. @AssertFalse(message = "fal必须为false")
  28. private boolean fal;
  29.  
  30. @Min(value = 1, message = "min必须为数字,其值大于或等于指定的最小值")
  31. private Integer min;
  32.  
  33. @Max(value = 10, message = "max必须为数字,其值小于或等于指定的最大值")
  34. private Integer max;
  35.  
  36. @DecimalMin(value = "1", message = "minDeci最小不能小于1")
  37. private BigDecimal minDeci;
  38.  
  39. @DecimalMax(value = "10", message = "maxDeci最大不能大于10")
  40. private BigDecimal maxDeci;
  41.  
  42. @Size(min = 1, max = 2, message = "list集合的长度最小不能小于1,最大不能大于2")
  43. private List<Object> list;
  44.  
  45. @Digits(integer = 4, fraction = 2, message = "digits整数位不能超过4个,小数位不能超过2个")
  46. private BigDecimal digits;
  47.  
  48. /**
  49. * 将前台传来的日期数据映射到此字段
  50. */
  51. @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
  52. @Past(message = "past必须为过去的日期")
  53. private Date past;
  54.  
  55. @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
  56. @Future(message = "future必须为将来的日期")
  57. private Date future;
  58.  
  59. @Pattern(regexp = "^1[3|4|5|7|8][0-9]{9}$", message = "phone必须符合正则表达式")
  60. private String phone;
  61.  
  62. @Email(message = "email必须是邮箱格式")
  63. private String email;
  64.  
  65. @Length(min = 1, max = 2, message = "length长度最小不能小于1,最大不能大于2")
  66. private String length;
  67.  
  68. @NotEmpty(message = "id不能为null,长度大于0")
  69. private String id;
  70.  
  71. @Range(min = 1, max = 12, message = "month最小不能小于1,最大不能大于12")
  72. private Integer month;
  73.  
  74. @NotBlank(message = "name不能为null,字段串长度大于0(限字符串)")
  75. private String name;
  76. }

2、封装返回响应体

  1. package com.clickpaas.response;
  2.  
  3. import lombok.AllArgsConstructor;
  4. import lombok.Data;
  5.  
  6. /**
  7. * @author 方延杰
  8. * @version 1.0
  9. * @since 2019/7/3 4:32 下午
  10. */
  11. @Data
  12. @AllArgsConstructor
  13. public class CodeMsg {
  14.  
  15. private int code;
  16.  
  17. private String msg;
  18.  
  19. /**
  20. * 失败
  21. */
  22. public static CodeMsg SERVER_ERROR = new CodeMsg(500, "服务端异常");
  23.  
  24. }
  1. package com.clickpaas.response;
  2.  
  3. import lombok.AllArgsConstructor;
  4. import lombok.Data;
  5.  
  6. /**
  7. * @author 方延杰
  8. * @version 1.0
  9. * @since 2019/7/3 4:35 下午
  10. */
  11. @Data
  12. @AllArgsConstructor
  13. public class Result<T> {
  14.  
  15. /**
  16. * 返回状态码 除200其余全部失败
  17. */
  18. private int code;
  19.  
  20. /**
  21. * 返回信息 除success其余全部失败
  22. */
  23. private String msg;
  24.  
  25. /**
  26. * 泛型数据
  27. */
  28. private T data;
  29.  
  30. /**
  31. * 成功时返回的类型
  32. *
  33. * @param data 数据
  34. * @param <T> 泛型
  35. * @return 泛型数据
  36. */
  37. public static <T> Result<T> success(T data) {
  38. return new Result<>(200, "success", data);
  39. }
  40.  
  41. public static <T> Result<T> fail(CodeMsg codeMsg) {
  42. return new Result<>(codeMsg);
  43. }
  44. private Result(CodeMsg codeMsg) {
  45. if (codeMsg == null) {
  46. return;
  47. }
  48. this.code = codeMsg.getCode();
  49. this.msg = codeMsg.getMsg();
  50. }
  51.  
  52. }

3、创建使用增强器拦截并返回异常信息

  1. package com.clickpaas.config;
  2.  
  3. import com.clickpaas.response.CodeMsg;
  4. import com.clickpaas.response.Result;
  5. import org.springframework.web.bind.MethodArgumentNotValidException;
  6. import org.springframework.web.bind.annotation.ExceptionHandler;
  7. import org.springframework.web.bind.annotation.RestControllerAdvice;
  8.  
  9. import javax.servlet.http.HttpServletRequest;
  10. import java.util.Objects;
  11.  
  12. /**
  13. * @author 方延杰
  14. * @version 1.0
  15. * @since 2018/12/10 4:59 下午
  16. */
  17. @RestControllerAdvice
  18. public class GlobalExceptionInterceptor {
  19.  
  20. @ExceptionHandler(value = MethodArgumentNotValidException.class)
  21. public Result<Object> exceptionHandler(HttpServletRequest request, Exception e) {
  22. String errMsg = "处理失败";
  23. if (e instanceof MethodArgumentNotValidException) {
  24. // 拿到参数校验具体异常信息
  25. errMsg = Objects.requireNonNull(((MethodArgumentNotValidException) e).getBindingResult().getFieldError()).getDefaultMessage();
  26. }
  27. return Result.fail(new CodeMsg(500, errMsg));
  28. }
  29. }

4、创建控制层测试

  1. package com.clickpaas.controller;
  2.  
  3. import com.clickpaas.pojo.Person;
  4. import org.springframework.validation.annotation.Validated;
  5. import org.springframework.web.bind.annotation.PostMapping;
  6. import org.springframework.web.bind.annotation.RequestBody;
  7. import org.springframework.web.bind.annotation.RestController;
  8.  
  9. /**
  10. * @author 方延杰
  11. * @version 1.0
  12. * @since 2020/12/10 9:03 下午
  13. */
  14. @RestController
  15. public class ValidController {
  16.  
  17. @PostMapping("/valid")
  18. public String valid(@Validated @RequestBody Person person) {
  19. return "success";
  20. }
  21.  
  22. }

5、测试符合验证请求体访问,请求体如下:

  1. {
  2. "death":null,
  3. "bool":true,
  4. "fal":false,
  5. "min":1,
  6. "max":10,
  7. "minDeci":1,
  8. "maxDeci":10,
  9. "list":[
  10. {},{}
  11. ],
  12. "digits":1144.12,
  13. "past":"2020-10-01 10:00:00",
  14. "future":"2022-10-01 10:00:00",
  15. "phone":"15900445584",
  16. "email":"yanjie.fang@clickpaas.com",
  17. "length":"ab",
  18. "id":" ",
  19. "name":"a"
  20. }

详解Java后端优雅验证参数合法性

6、故意修改不符合验证的数据

详解Java后端优雅验证参数合法性

7、如果想做整体验证,如下:

  1. package com.clickpaas.uitl;
  2.  
  3. import javax.validation.ConstraintViolation;
  4. import javax.validation.Validation;
  5. import javax.validation.Validator;
  6. import java.util.List;
  7. import java.util.Set;
  8. import java.util.stream.Collectors;
  9.  
  10. /**
  11. * Bean整体校验工具类
  12. *
  13. * @author 方延杰
  14. * @version 1.0
  15. * @since 2020/12/10 10:08 下午
  16. */
  17. public class ValidatorUtils {
  18.  
  19. private static final Validator VALIDATOR = Validation.buildDefaultValidatorFactory().getValidator();
  20.  
  21. /**
  22. * Bean整体校验,有不合规范,拼接message
  23. */
  24. public static String validate(Object obj, Class<?>... groups) {
  25.  
  26. StringBuilder errorMessage = new StringBuilder();
  27.  
  28. Set<ConstraintViolation<Object>> resultSet = VALIDATOR.validate(obj, groups);
  29. if (resultSet.size() > 0) {
  30. //如果存在错误结果,则将其解析并进行拼凑后异常抛出
  31. List<String> errorMessageList = resultSet.stream().map(ConstraintViolation::getMessage).collect(Collectors.toList());
  32. errorMessageList.forEach(o -> errorMessage.append(o).append(";"));
  33. }
  34. return errorMessage.toString();
  35. }
  36.  
  37. }

8、整体测试类

详解Java后端优雅验证参数合法性

到此这篇关于详解Java后端优雅验证参数合法性的文章就介绍到这了,更多相关Java 验证参数合法性内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_48314739/article/details/111012090

标签:

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部