写在前面
今天开发excel导入数据的功能,一切都很顺利。但是当看到需求文档,其中有几个列的数据是必输的。于是我想到了,在实体类属性上加@NotBlank注解不就可以了嘛!但是我写接口入参是一个文件,所以解析实体后这个注解根本不起作用。于是想到自己创建自定义注解,校验非空的列。
正题
1.创建注解类
写过注解的同学应该都比较熟悉了,直接上代码。
字符串非空校验
/**
* Excel导入必填校验注解
*
*/
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelValid {
String message() default "非空字段必填";
}
字符串长度校验注解
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelStrLengthValid {
int length() default 0;
String message() default "字段超长";
}
int长度校验
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelIntValid {
int min();
int max();
String message() default "整数超过长度范围";
}
还可以写其他类型的校验注解,这里就不展示了。
2.导入字段检验逻辑
public class ExcelInValid {
/**
* Excel导入字段校验
*
* @param object 校验的JavaBean 其属性须有自定义注解
* @author linmaosheng
*/
public static void valid(Object object) {
Field[] fields = object.getClass().getDeclaredFields();
for (Field field : fields) {
field.setAccessible(true);
//属性的值
Object fieldValue = null;
try {
fieldValue = field.get(object);
} catch (IllegalAccessException e) {
//B