一个项目思路(2):界面属性到po层的赋值

主要为了减少写一些赋值操作:


    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 ——>数据库

但有一个不好的地方: 数据转换时,比对是根据 属性名称,导致 界面元素的名称 直接和 数据库中该属性名称 一样 ,从安全上讲,不好

  还没想好怎么解决,大神不妨指点一番

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值