@NotEmpty、@NotBlank、@NotNull 区别和使用
首先需要说明下,本提到的 @NotEmpty、@NotBlank、@NotNull 分别是
javax.validation.constraints.NotEmpty、javax.validation.constraints.NotBlank 、javax.validation.constraints.NotNull。
通过注解的方式我们可以更加优雅的对参数的格式进行校验,但是在使用 @NotEmpty、@NotBlank、@NotNull 的过程中,由于含义有点类似,所以导致使用的时候会有一些迷茫,下面,对这三个注解逐一进行使用上的说明:
@NotNull
适用于基本数据类型(Integer,Long,Double等等),当 @NotNull 注解被使用在 String 类型的数据上,则表示该数据不能为 Null(但是可以为 Empty)
@NotBlank
适用于 String 类型的数据上,加了@NotBlank 注解的参数不能为 Null 且 trim() 之后 size > 0
@NotEmpty
适用于 String、Collection集合、Map、数组等等,加了@NotEmpty 注解的参数不能为 Null 或者 长度为 0
在使用这些注解的时候,还需要注意一点(注:否则会造成注解无效哦!!),那就是在Controller 层定义方法的时候在参数位置上加上 @Valid(javax.validation.Valid) 注解!!!如下图:
这两个参数必须挨着,否则会报错400
Utils工具类
public class Utils {
private static Logger log = LoggerFactory.getLogger(Utils.class);
public static ObjectMapper mapper = new ObjectMapper();
public Utils() {
}
public static String toJSONString(Object obj) {
if (null == obj) {
return null;
} else {
try {
return mapper.writeValueAsString(obj);
} catch (JsonProcessingException var2) {
log.error("系统异常:", var2);
return null;
}
}
}
public static void info(Object info) {
try {
System.out.println(mapper.writeValueAsString(info));
} catch (Exception var2) {
log.error("系统异常:", var2);
}
}
public static void info(Logger log, String info, Object... objs) {
try {
String[] strs = new String[objs.length];
for(int i = 0; i < objs.length; ++i) {
Object o = objs[i];
strs[i] = mapper.writeValueAsString(o);
}
log.info(info, strs);
} catch (Exception var6) {
log.error("系统异常:", var6);
}
}
public static String getReturnErrors(List<ObjectError> list) {
Map<String, String> fieldErrors = new HashMap();
Iterator var2 = list.iterator();
String key;
while(var2.hasNext()) {
ObjectError fieldError = (ObjectError)var2.next();
key = fieldError.getCode();
String msg = fieldError.getDefaultMessage()