1. 程式人生 > >對前臺傳過來的實體是否為空 進行為空校驗的N種方法

對前臺傳過來的實體是否為空 進行為空校驗的N種方法

common 編譯 response spl rst maps 校驗 mod 維護

首先定義一個註解,如下

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 ParamNotNull {
}

  

簡單解釋一下,interface前面加@的意思是:

@interface 不是interface,是註解類
是jdk1.5之後加入的,java沒有給它新的關鍵字,所以就用@interface 這麽個東西表示了
這個註解類,就是定義一個可用的註解,包括這個註解用於什麽地方,是類,還是方法,還是property,還是方法入參等等,還有這個註解是否編譯後進入class
比如我們知道的用於javadoc的註解,是不進入class文件的。然後在後面你就可以用這個註解寫代碼了。
總的來說,這就是一個生成javadoc時用到的註釋類



/**
* 對非空參數進行校驗,使用註解
* @param model javabean 對象
* @throws ClassNotFoundException


*/
public static CheckResult parameterIsNotNull(Object model) {
try {
Field[] fields = model.getClass().getDeclaredFields();
boolean flag = true;
String fieldstr = "字段:";
for (Field field : fields) {
ParamNotNull annotation = field.getAnnotation(ParamNotNull.class);

if(annotation != null){
String name = field.getName();
if(!chechFiled(model,name,field)){
flag = false;
fieldstr = fieldstr + name + " ";
}
}
}
if(flag){//校驗通過
return new CheckResult(true);
}else {//有參數校驗不通過
return new CheckResult(ApiResponse.error(Syscode.PARAMETER_ERROR,fieldstr+"不能為空!"));
}
}catch (Exception e){
LOG.error(CheckParameter.class,"對非空參數進行校驗時異常 e: " + e.getMessage());
return new CheckResult(ApiResponse.error(Syscode.SYSTEM_EXCEPTION));
}
}

private static boolean chechFiled(Object model,String name,Field field) throws Exception{
boolean flag = true;
name = name.substring(0,1).toUpperCase()+name.substring(1); //將屬性的首字符大寫,方便構造get,set方法
String type = field.getGenericType().toString(); //獲取屬性的類型
if(type.equals("class java.lang.String")){ //如果type是類類型,則前面包含"class ",後面跟類名
Method m = model.getClass().getMethod("get"+name);
String value = (String) m.invoke(model); //調用getter方法獲取屬性值
if(StringUtils.isBlank(value)){
flag = false;
}
}else {
Method m = model.getClass().getMethod("get"+name);
Object value = m.invoke(model);
if(value == null){
flag = false;
}
}
return flag;
}


或者只使用反射機制

/**
* 對非空參數進行校驗
* @param model javabean 對象
* @param unCheckField 不校驗的字段
* @return
*/
public static CheckResult parameterIsNotNull(Object model, Set<String> unCheckField){
try {
boolean flag = true;
String fieldstr = "字段:";
Field[] field = model.getClass().getDeclaredFields(); //獲取實體類的所有屬性,返回Field數組
for(int j=0 ; j<field.length ; j++){ //遍歷所有屬性
String name = field[j].getName(); //獲取屬性的名字
if(unCheckField.contains(name)){
continue;//不需要校驗此字段
}
if(!chechFiled(model,name,field[j])){
flag = false;
fieldstr = fieldstr + name + " ";
}
}
if(flag){//校驗通過
return new CheckResult(true);
}else {//有參數校驗不通過
return new CheckResult(ApiResponse.error(Syscode.PARAMETER_ERROR,fieldstr+"不能為空!"));
}
}catch (Exception e){
LOG.error(CheckParameter.class,"對非空參數進行校驗時異常 e: " + e.getMessage());
return new CheckResult(ApiResponse.error(Syscode.SYSTEM_EXCEPTION));
}
}

import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import com.yucheng.cmis.channel.stagedaccess.domain.MapsStagedMaintainInfo;
/**
* 校驗參數是否為空
* @author xr
* @param model:參數所在的實體類 paramList:要校驗的參數
*
*/
public class ParamCheck {
public static boolean isNotBlank(Object model,List<String> paramList) throws Exception, Exception {
boolean flag = true;
String params = "";
String param = "";
for(int i=0;i<paramList.size();i++) {
params = paramList.get(i);
if (params.indexOf("_") < 0) {
params = params.substring(0,1).toUpperCase()+params.substring(1); //將屬性的首字符大寫,方便構造get,set方法
System.out.println(params);
Method m = model.getClass().getMethod("get"+params);
String value = (String) m.invoke(model); //調用getter方法獲取屬性值
if(StringUtils.isBlank(value)){
flag = false;
return flag;
}
} else {
String[] strs = params.split("_");
for (int j=0;j<strs.length;j++) {
params = strs[j].substring(0,1).toUpperCase()+strs[j].substring(1); //將屬性的首字符大寫,方便構造get,set方法
param += params;
System.out.println(param);
}
Method m = model.getClass().getMethod("get"+param);
String value = (String) m.invoke(model); //調用getter方法獲取屬性值
if(StringUtils.isBlank(value)){
flag = false;
return flag;
}
}
}
return flag;
}
public static void main(String[] args) throws Exception {
//維護人員信息
MapsStagedMaintainInfo mainInfo = new MapsStagedMaintainInfo();
//mainInfo.setHead("aa");
mainInfo.setBusiManagerStore("bbb");
List<String> paramList = new ArrayList<String>();
paramList.add("head");
paramList.add("busi_manager_store");
boolean result = ParamCheck.isNotBlank(mainInfo, paramList);
System.out.println(result);
}

對前臺傳過來的實體是否為空 進行為空校驗的N種方法