主要为了减少写一些赋值操作:
public static void enumerate(Map map,Object bo )
{
HashMap hashmap=(HashMap)map;
Method[] methods = bo.getClass().getMethods();
int bolength=bo.getClass().getMethods().length;
String bosetMethodName =null;//po的set方法名称
Method bosetMethod = null;//bo的set方法
String fieldName=null;
for(int i = 0; i <bolength; i++)
{
String methodName=methods[i].getName();//取得每个方法的名称
if(methodName.substring(0, 3).equals("set"))//判断是否是get方法
{
try
{
bosetMethod=methods[i];//获得bo的set方法
fieldName=methodName.substring(3);//属性名称
Object value=hashmap.get(fieldName);//获得属性名称所代表的属性值(map是页面传过来的字符串组)
if(value!=null)
{
Class<?>[] clazz = bosetMethod.getParameterTypes();//获得set方法参数的类型
String type = clazz[0].getName();
System.out.println("bo的set方法:"+bosetMethod.getName()+" "+fieldName+"参数类型为:"+type);
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-mm-dd");
if(type.equals("java.lang.String")){
bosetMethod.invoke(bo,(String)value);
}
else if(type.equals("java.util.Date")){
bosetMethod.invoke(bo,sdf.parse((String)value));
}
else if(type.equals("java.lang.Integer")){
bosetMethod.invoke(bo, new Integer((String)value));
}
}
}catch(Exception e)
{
System.out.println("bo的set方法:"+bosetMethod.getName()+"没有设置 值 进去");
}
}
}
}
相应的测试:
public void testEvalin()//po.setName(bo。getName) 其实也可以是 bo.setName(po.getName),从输入数据导入数据库验证
{
CustomBO bo=new CustomBO("0007", "哈xxx","大xxx",1,"小明","0001", 1,
0, 5, 5, "福州aa", "362600",
"10086", "10086", "www.fuzhou.com", "1", "辉哥",
500, 500, "工商银行", "111111111", "2", "22",new Date());
CustomPO po=new CustomPO();
eval.eval(bo, po);
System.out.println("bo对象自带getclass方法:"+po.getClass());
System.out.println(po.getC_no());
System.out.println(po.getC_comp());
System.out.println(po.getArea_no());
System.out.println(po.getEmpno());
System.out.println(po.getC_level());
System.out.println(po.getC_state());
System.out.println(po.getC_sat());
System.out.println(po.getC_cred());
System.out.println(po.getC_addr());
System.out.println(po.getC_post());
System.out.println(po.getC_phone());
System.out.println(po.getC_fax());
System.out.println(po.getC_url());
System.out.println(po.getC_regno());
System.out.println(po.getC_lawman());
System.out.println(po.getC_regfund());
System.out.println(po.getC_turnover());
System.out.println(po.getC_optank());
System.out.println(po.getC_bankno());
System.out.println(po.getC_loctax());
System.out.println(po.getC_nattax());
System.out.println(po.getC_losedate()+"类型:"+bo.getC_losedate().getClass());
//试试得到的这个po能否导入数据库
CustomDAOImpl customDAO=new CustomDAOImpl();
customDAO.addCustom(po);
}
这个 思路为:取数据: 数据库 ——>(数据类型转化)po ——>bo
存数据:request.getParameterMap()得到map ——>bo ——>po ——>数据库
但有一个不好的地方: 数据转换时,比对是根据 属性名称,导致 界面元素的名称 直接和 数据库中该属性名称 一样 ,从安全上讲,不好
还没想好怎么解决,大神不妨指点一番