要自定义注解实现数据校验,可以按照以下步骤:
@interface
关键字定义注解。例如:import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.FIELD) // 注解作用在字段上
@Retention(RetentionPolicy.RUNTIME) // 注解在运行时可见
public @interface Validate {
String value(); // 定义注解参数
}
public class User {
@Validate("username")
private String username;
@Validate("password")
private String password;
// 省略getter和setter方法
}
import java.lang.reflect.Field;
public class Validator {
public static boolean validate(Object obj) {
Field[] fields = obj.getClass().getDeclaredFields();
for (Field field : fields) {
if (field.isAnnotationPresent(Validate.class)) {
Validate validate = field.getAnnotation(Validate.class);
String value = validate.value();
// 根据注解参数进行数据校验逻辑,例如验证用户名和密码不为空
field.setAccessible(true);
try {
Object fieldValue = field.get(obj);
if (fieldValue == null || fieldValue.toString().isEmpty()) {
System.out.println(value + " is empty");
return false;
}
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
return true;
}
}
public class Main {
public static void main(String[] args) {
User user = new User();
user.setUsername("admin");
user.setPassword("");
boolean isValid = Validator.validate(user);
System.out.println("is valid: " + isValid);
}
}
以上示例中,自定义的@Validate
注解用来标记需要进行数据校验的字段,Validator.validate()
方法根据注解参数进行数据校验逻辑,并返回校验结果。在主程序中,创建了一个User
对象,并使用Validator.validate()
方法进行数据校验。