自定义注解做数据验证
為了工作也為了更加深入了解掌握java注解的使用,決定自定義注解來實現數據驗證。
最開始也考慮使用jsr-303規范來實現功能,但是對于開發人員來說比較累,因為要去實體類對象中添加驗證字段注解,而且要進入到method當中。上一篇寫的springmvc數據驗證就是用jsr-303規范實現的。今天自定義了一下。也挺不錯。
? ? ? ?自定義注解:
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Validator {
public String[] fields();
public String bean() default "";
}
controller:
@RequestMapping(value="index3.do",method=RequestMethod.POST)
@ResponseBody
@Validator(fields={"username"+ValidatorConstant.NOT_NULL,"age"+ValidatorConstant.NOT_NULL},bean="myValidatorService")
public JSONObject index3(User user,HttpServletRequest request) {
JSONObject ret=new JSONObject();
ret.put("cuixuefeng", "25歲");
return ret;
}
其中fields是對應屬性字段進行設置,bean是自定義Validator接口實現。
? ? ? ?過濾器:
public class MyHandler extends HandlerInterceptorAdapter implements ApplicationContextAware{
private static ApplicationContext ac;
/**
* 請求執行前攔截
* @param request 請求對象
* @param response 響應對象
* @param
*/
@Override
public boolean preHandle(HttpServletRequest request,?
HttpServletResponse response, Object handler) throws Exception {
HandlerMethod method=(HandlerMethod)handler;
Class<?> clazz=method.getBean().getClass();
String method_name=method.getMethod().getName();
return ValidatorUtil.getMethodInfo(clazz, method_name,request,ac);
}
/* (non-Javadoc)
* @see org.springframework.context.ApplicationContextAware#setApplicationContext(org.springframework.context.ApplicationContext)
*/
@Override
public void setApplicationContext(ApplicationContext arg0)
throws BeansException {
// TODO Auto-generated method stub
ac=arg0;
}
}
注解處理類:
public class ValidatorUtil {
public static boolean getMethodInfo(Class<?> clazz,String method_name,HttpServletRequest request,ApplicationContext ac){
Method[] methods = clazz.getDeclaredMethods();
? ? for(Method method :methods){
? ? if(method.getName().equals(method_name)){
? ? if(method.isAnnotationPresent(Validator.class)){
? ? Validator validator = method.getAnnotation(Validator.class);
? ? String[] fields=validator.fields();
? ? String bean=validator.bean();
? ? if(!verify(fields, request)){
? ? return false;
? ? }else{
? ? if(!"".equals(bean)){
? ? return ((IValidatorService)ac.getBean(bean)).verify(request);
? ? }
? ? }
? ? ? ? }
? ? ? ?}
? ?}
? ?return true;
}
?
public static boolean verify(String[] fields,HttpServletRequest request) {
for(String field:fields){
String[] params=field.split(":");
if(!verify(params[1], request.getParameter(params[0]))){
return false;?
}
}
return true;
}
?
public static boolean verify(String type,String param) {
if(type.equals(ValidatorConstant.NOT_NULL.substring(1))){ //校驗非空
if(param==null||"".equals(param)){
return false;
}
}else if (type.equals(ValidatorConstant.NOT_ZERO.substring(1))) {//校驗為0
if(param.equals("0")){
return false;
}
}else if (type.equals(ValidatorConstant.PHONE_NUM.substring(1))) {//校驗手機號碼11位
if(!(param.length()==11)){
return false;
}
}else if (type.equals(ValidatorConstant.ID_CARD.substring(1))) {//校驗身份證合法
return IdCardUtil.verify(param);
}
return true;
}
?
}
注解類型參數:
public class ValidatorConstant {
/**
* 非空
*/
public static final String NOT_NULL=":NOT_NULL";
/**
* 不等于0
*/
public static final String NOT_ZERO=":NOT_ZERO";
/**
* 日期格式
*/
public static final String DATE_FORMAT=":DATE_FORMAT";
/**
* email格式
*/
public static final String EMAIL_FORMAT=":EMAIL_FORMAT";
/**
* 身份證校驗
*/
public static final String ID_CARD=":ID_CARD";
/**
* 字符長度
*/
public static final String STR_LENGTH=":STR_LENGTH";
/**
* 正則表達式
*/
public static final String REG_EXP=":REG_EXP";
/**
* 手機號碼校驗
*/
public static final String PHONE_NUM=":PHONE_NUM";
}
以上實現其實是兩個功能并列的關系,注解中接收兩個參數:fields和bean,通過標簽寫入的fields可以實現基本校驗,復雜的校驗需要重新實現service進行實現。
接口:
public interface IValidatorService {
/**
* 校驗(復雜校驗方法)
* @param request 請求參數
* @return boolean 通過校驗返回true否則返回false
*/
public boolean verify(HttpServletRequest request);
}
總結
以上是生活随笔為你收集整理的自定义注解做数据验证的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: springmvc数据验证
- 下一篇: JVM参数配置