- Valid验证
1.1 Valid基本验证
原来的判断更多的是通过程序员编写逻辑代码完成验证,现在可以通过注解方式完成,我们首先需要加入新的maven驱动:
javax.validation validation-api2.0.1.Final org.hibernate hibernate-validator6.2.0.Final
注意:第一个驱动是java自身的验证规则,第二个驱动是hibernate提供的一种验证方式,如果只用java自身的验证规则,则不需要引入第二个驱动,后续我们会看到两种驱动所带来的不同的注解式验证。
接下来,我们来做一个最基本的演示,例如:
@GetMapping("/test") @ResponseBody public String test(@Valid User user) { System.out.println("user=" + user); return "Hello World!"; }
这里,我们可以在接收的vo对象前,加入@Valid验证,在vo对象属性头上添加对应的注解完成验证 *** 作,例如:
public class User { @Min(value = 1, message = "主键id必须大于0") private int id; @NotBlank(message = "姓名不能为空") @Size(min = 6, max = 10, message = "size 姓名必须在6~10位之间") private String username; ...... }
接着,我们通过get请求,只传递username:
http://localhost:8080/check?username=thinknovo
那么我们在页面上讲看到下面的错误信息:
如果我们希望返回的json错误信息,那么需要手动创建一个ExceptionHandler,例如:
@ExceptionHandler @ResponseBody public Mapcheck(Exception e) { e.printStackTrace(); Map map = new HashMap<>(); map.put("code", 500); map.put("msg", e.getMessage()); return map; }
最后,我们能看到页面返回的json数据:
{“msg”:“org.springframework.validation.BeanPropertyBindingResult: 1 errorsnField error in object ‘user’ on field ‘id’: rejected value [0]; codes [Min.user.id,Min.id,Min.int,Min]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [user.id,id]; arguments []; default message [id],1]; default message [主键id必须大于0]”,“code”:500}
1.2 常用注解说明(包括Java自身和Hibernate验证注解):
@Null
限制前端传递数据只能为null
@NotNull
限制前端传递数据必须不为null
@AssertFalse
限制前端传递数据必须为false
@AssertTrue
限制前端传递数据必须为true
@DecimalMax(value)
限制前端传递数据必须为一个不大于指定值的数字
@DecimalMin(value)
限制前端传递数据必须为一个不小于指定值的数字
@Digits(integer,fraction)
限制前端传递数据必须为一个小数(检查小数点),且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Future
限制前端传递数据必须是一个将来的日期
@Max(value)
限制前端传递数据必须为一个不大于指定值的数字
@Min(value)
限制前端传递数据必须为一个不小于指定值的数字
@Past
限制前端传递数据必须是一个过去的日期
@Pattern(value)
限制前端传递数据必须符合指定的正则表达式
@Size(max,min)
限制前端传递数据字符长度必须在min到max之间
@Past
验证前端传递数据(日期类型)比当前时间早
@NotEmpty
验证前端传递数据不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank
验证前端传递数据不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email
验证前端传递数据是Email,也可以通过正则表达式和flag指定自定义的email格式
- 异常统一拦截
@ControllerAdvice @ResponseBody public class ExceptionControllerAdvice { @ExceptionHandler @ResponseBody public Mapcheck(Throwable e) { e.printStackTrace(); Map map = new HashMap<>(); map.put("code", 500); map.put("msg", e.getMessage()); return map; } }
定义一个异常拦截类,和SpringMVC一样,然后把异常的message信息直接封装在msg字段中,这样当抛出错误,就会返回一个错误信息的json数据,例如:
- JackSon手动返回json数据
在某些情况下,我们需要手动创建一个json对象返回,而不能完全依赖SpringMVC自动返回,这时候,我们可以手动编写JackSon的json转换:
Mapmap = new HashMap<>(); map.put("code", 500); map.put("msg", "用户未登录,无法使用此功能"); ObjectMapper objectMapper = new ObjectMapper(); String jsonStr = objectMapper.writevalueAsString(map);
如果需要把一个jsonStr手动转换成一个java类对象,可以通过下面的方式完成:
ObjectMapper mapper = new ObjectMapper(); User user = mapper.readValue(jsonStr, User.class);
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)