项目用到了springboot,本来很高兴,但是项目里什么东西都没有,验证,全局异常这些都需要自己区配置。最近springboot用的还是蛮多的,我还是做事情,把经验发表一下.
SpringBoot提供了强大的表单验证功能实现,给我们省去了写验证的麻烦
1.在传参类的属性上加注解
@NotEmpty(message="姓名不能为空!")
private String name;
2.在controller层方法上,传参类加个@valid,并加个BindingResult 验证结果对象.
public String method(@Valid 传参类 xxx,BindingResult bindingResult){
if(bindingResult.hasErrors()){
return bindingResult.getFieldError().getDefaultMessage();
}
}
以下是常用的springboot表单验证的注解。
限制 说明
@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格式
另外还有一种返回方式:
package com.lianrong.system.utils;
import com.lianrong.system.bean.SystemCodeEntity;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import javax.validation.ConstraintViolation;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.groups.Default;
public class ValidatorUtil {
private static Validator validator = Validation.buildDefaultValidatorFactory()
.getValidator();
public static <T> Map<String,StringBuffer> validate(T obj){
Map<String,StringBuffer> errorMap = null;
Set<ConstraintViolation<T>> set = validator.validate(obj,Default.class);
if(set != null && set.size() >0 ){
errorMap = new HashMap<String,StringBuffer>();
String property = null;
for(ConstraintViolation<T> cv : set){
//这里循环获取错误信息,可以自定义格式
property = cv.getPropertyPath().toString();
if(errorMap.get(property) != null){
errorMap.get(property).append("," + cv.getMessage());
}else{
StringBuffer sb = new StringBuffer();
sb.append(cv.getMessage());
errorMap.put(property, sb);
}
}
}
return errorMap;
}
/**
public static void main(String[] args) {
SystemCodeEntity systemCodeEntity = new SystemCodeEntity();
print(ValidatorUtil.validate(systemCodeEntity));
}*/
public static StringBuffer print(Map<String,StringBuffer> errorMap){
StringBuffer result = new StringBuffer("");
if(errorMap != null){
for(Map.Entry<String, StringBuffer> m : errorMap.entrySet()){
System.out.println(m.getKey() + ":" + m.getValue().toString());
result.append(m.getKey() + "" +m.getValue().toString()+",");
}
}
return result;
}
}
@Valid,也不用传参数BindingResult
StringBuffer resultMsg = ValidatorUtil.print(
ValidatorUtil.validate(systemCodeVo)
);
if(resultMsg.length() > 0){
return JsonData.error(resultMsg.toString());
}
提出一个小问题,增加不需要id,修改需要id,可以利用验证框架的分组功能groups
public interface Default{}
public interface Update{}
/**
* 编号.
*/
@NotNull(message = "id不能为空",groups = Update.class)
private Integer id;
/**
* 状态码
*/
@NotBlank(message = "请输入状态码",groups = Default.class)
private String type_code;
@RequestMapping(value="/save",method = RequestMethod.POST)
@ResponseBody
public JsonData save(@RequestBody @Validated(value = Wordbookform.Default.class)