转自:http://blog.csdn.net/zhao19861029/article/details/8473245

首先实现生成对应的JAVAbean的XML文件方法

/**
     * DMO4J写入XML
     * @param obj        泛型对象
     * @param entityPropertys 泛型对象的List集合
     * @param Encode     XML自定义编码类型(推荐使用GBK)
     * @param XMLPathAndName    XML文件的路径及文件名
     */
    public void writeXmlDocument(T obj, List<T> entityPropertys, String Encode,
            String XMLPathAndName) {
        long lasting = System.currentTimeMillis();//效率检测   

        try {
            XMLWriter writer = null;// 声明写XML的对象
            OutputFormat format = OutputFormat.createPrettyPrint();
            format.setEncoding(Encode);// 设置XML文件的编码格式   

            String filePath = XMLPathAndName;//获得文件地址
            File file = new File(filePath);//获得文件     

            if (file.exists()) {
                file.delete();   

            }
            // 新建student.xml文件并新增内容
            Document document = DocumentHelper.createDocument();
            String rootname = obj.getClass().getSimpleName();//获得类名
            Element root = document.addElement(rootname + "s");//添加根节点
            Field[] properties = obj.getClass().getDeclaredFields();//获得实体类的所有属性   

            for (T t : entityPropertys) {                                //递归实体
                Element secondRoot = root.addElement(rootname);            //二级节点   

                for (int i = 0; i < properties.length; i++) {
                    //反射get方法
                    Method meth = t.getClass().getMethod(
                            "get"
                                    + properties[i].getName().substring(0, 1)
                                            .toUpperCase()
                                    + properties[i].getName().substring(1));
                    //为二级节点添加属性,属性值为对应属性的值
                    secondRoot.addElement(properties[i].getName()).setText(
                            meth.invoke(t).toString());   

                }
            }
            //生成XML文件
            writer = new XMLWriter(new FileWriter(file), format);
            writer.write(document);
            writer.close();
            long lasting2 = System.currentTimeMillis();
            System.out.println("写入XML文件结束,用时"+(lasting2 - lasting)+"ms");
        } catch (Exception e) {
            System.out.println("XML文件写入失败");
        }   

    }  

测试此方法

/**
 * DOM4J读写XML示例
 *
 * @param args
 * @throws Exception
 */  

public static void main(String[] args) {
    DOM4JTest<User> d = new DOM4JTest<User>();
    User user = new User();
    User user1 = new User("姓名1", "18", "男");
    User user2 = new User("姓名2", "19", "女");
    User user3 = new User("石头", "20", "女");   

    List<User> users = new ArrayList<User>();
    users.add(user1);
    users.add(user2);
    users.add(user3);   

    d.writeXmlDocument(user, users, "GBK", "WebRoot\\WEB-INF\\student.xml");   

}  

此时得到的XML文件如下

view plaincopy to clipboardprint?
<?xml version="1.0" encoding="GBK"?>  

<Users>
  <User>
    <name>姓名1</name>
    <age>18</age>
    <sax>男</sax>
  </User>
  <User>
    <name>姓名2</name>
    <age>19</age>
    <sax>女</sax>
  </User>
  <User>
    <name>石头</name>
    <age>20</age>
    <sax>女</sax>
  </User>
</Users>  

实现读取XML文件得到对象集合的方法

/**
 *
 * @param XMLPathAndName XML文件的路径和地址
 * @param t     泛型对象
 * @return
 */  

    @SuppressWarnings("unchecked")
    public List<T> readXML(String XMLPathAndName, T t) {
        long lasting = System.currentTimeMillis();//效率检测
        List<T> list = new ArrayList<T>();//创建list集合
        try {
            File f = new File(XMLPathAndName);//读取文件
            SAXReader reader = new SAXReader();
            Document doc = reader.read(f);//dom4j读取
            Element root = doc.getRootElement();//获得根节点
            Element foo;//二级节点
            Field[] properties = t.getClass().getDeclaredFields();//获得实例的属性
            //实例的get方法
            Method getmeth;
            //实例的set方法
            Method setmeth;   

            for (Iterator i = root.elementIterator(t.getClass().getSimpleName()); i.hasNext();) {//遍历t.getClass().getSimpleName()节点
                foo = (Element) i.next();//下一个二级节点   

               t=(T)t.getClass().newInstance();//获得对象的新的实例   

               for (int j = 0; j < properties.length; j++) {//遍历所有孙子节点   

                    //实例的set方法
                      setmeth = t.getClass().getMethod(
                            "set"
                                    + properties[j].getName().substring(0, 1)
                                            .toUpperCase()
                                    + properties[j].getName().substring(1),properties[j].getType());
                  //properties[j].getType()为set方法入口参数的参数类型(Class类型)
                    setmeth.invoke(t, foo.elementText(properties[j].getName()));//将对应节点的值存入   

                }   

                list.add(t);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        long lasting2 = System.currentTimeMillis();
        System.out.println("读取XML文件结束,用时"+(lasting2 - lasting)+"ms");
        return list;
    }  

测试:

public static void main(String[] args) {
        DOM4JTest<User> d = new DOM4JTest<User>();
        User user = new User();   

        List<User> list=  d.readXML("WebRoot\\WEB-INF\\student.xml",user);
    System.out.println("XML文件读取结果");
    for(int i =0;i<list.size();i++){
        User usename=(User)list.get(i);
        System.out.println("name"+usename.getName());
        System.out.println("age"+usename.getAge());
        System.out.println("sax"+usename.getSax());   

    }   

}  

控制台打印结果:

name姓名1
 age18
 sax男
name姓名2
 age19
 sax女
name石头
age20
 sax女

利用反射与dom4j读取javabean生成对应XML和读取XML得到对应的javabean对象集合的更多相关文章

  1. 利用反射与dom4j读取javabean生成对应XML

    项目中需要自定义生成一个xml,要把Javabean中的属性拼接一个xml,例如要生成以下xml <?xml version="1.0" encoding="gb2 ...

  2. 利用反射获取数据列+emit生成属性+单例模式

    1:IDictionary<string,string > 可以存储数据,将拼接的sql可以存储到这里下次可以使用 定义自定义属性表和列 typeof(T).GetCustomAttrib ...

  3. C#回顾 - 8.利用反射动态创建对象

    拿微信消息返回的示例数据实验 var data = "<xml><ToUserName><![CDATA[toUser]]></ToUserName ...

  4. 利用反射生成JDK动态代理

    利用反射生成JDK动态代理 在Java的java.lang.reflect包下提供了一个Proxy类和一个InvocationHandler接口,通过使用这个类和接口可以生成JDK动态代理类和动态代理 ...

  5. java反射并不是什么高深技术,面向对象语言都有这个功能,而且功能也很简单,就是利用jvm动态加载时生成的class对象

    java反射并不是什么高深技术,面向对象语言都有这个功能. 面向对象语言都有这个功能,而且功能也很简单,就是利用jvm动态加载时生成的class对象,去获取类相关的信息 2.利用java反射可以调用类 ...

  6. Java——利用反射机制将表单数据自动填充到JavaBean中

    以一个案例介绍反射机制的一种常见的使用场景,以及具体实现. 1.本文案例 在编写Java Web应用程序时,使用表单提交数据是一个必不可少的环节,后台对于前台使用表单提交的数据需要能够从请求中解析,并 ...

  7. 利用java反射动态调用方法,生成grid数据

    项目中需要java后台查询并组装前台grid的数据,数据行数不定,数据行定义不定,开始用了最原始的方法,写了几百行,就是前台需要什么字段后台拼接什么字段,java代码冗余量非常大,并且不够灵活,一旦前 ...

  8. <五>JDBC_利用反射及JDBC元数据编写通用的查询方法

    此类针对javaBean类写了一个通用的查询方法,List<javaBean> 通用查询更新中...:通过学习,深刻体会到学会反射就等于掌握了java基础的半壁江山! 一.使用JDBC驱动 ...

  9. 第十篇 一个利用反射实现的Excel导出

    前些天写了个导出Excel的公共类,因为项目中也需要上传Excel,没有利用Office组件,(PS:Office在上传文件时候,Excel进程无法关闭,会导致上传和打开失败)有的说利用Kill把进程 ...

随机推荐

  1. Raspberry pi(-) Mac下安装系统

    购买树莓派一般的操作说明书都是windows下的,因为本人只有MBP,外加虚拟机Parallels Desktop无法识别SD卡,所以就直接参考Mac教程了. 1.系统镜像官网下载 推荐用Raspbi ...

  2. top 10 tipis on Logging in Java- Tutorial (翻译)

    开篇废话,就记得出国之前有一回腾讯面试,面试官说既然你都快要出国了,英语肯定挺不错的,那为什么不去翻译一些国外好的文章呢,我希望找一个能主动学习的人,一直受教.目前在实习,需要做大数据相关方向,都是挺 ...

  3. 最新原创:Power8伴随云计算横空出世

    Power8伴随云计算横空出世 自从IBM将并不赚钱的x86服务器业务转手给联想之后,从此IBM便开始了硬件转型的新里程碑.伴随此事继续发酵的还有Power System Linux落户北京,从此IB ...

  4. Hibernate单元测试工具junit

    相关注解 @Text :测试方法 @Before :初始化方法 @After : 释放资源

  5. border在IE6设置transparent无效

    在ie6下给border设置transparent是无效的,解决办法如下: _border-color:tomato; /*For IE6-*/ _filter:chroma(color=tomato ...

  6. Reactor模式通俗解释

    Reactor这个词译成汉语还真没有什么合适的,很多地方叫反应器模式,但更多好像就直接叫reactor模式了,其实我觉着叫应答者模式更好理解一些.通过了解,这个模式更像一个侍卫,一直在等待你的召唤,或 ...

  7. 二叉树遍历(Binary Tree Traversal)

    二叉树的递归遍历比较简单,这里说一下非递归遍历,以中序遍历为例子. 非递归遍历主要用到栈来协助进行.对于一个二叉树,首先根节点入栈,如果有左儿子,则继续入栈,重复直到最左边的儿子,这时候此节点值为要遍 ...

  8. HTTP状态码大全

    完整的 HTTP 1.1规范说明书来自于RFC 2616,你可以在http://www.talentdigger.cn/home/link.php?url=d3d3LnJmYy1lZGl0b3Iub3 ...

  9. JDK&JRE&JVM

    JDK:—Java Development kit  (Java开发工具包) JRE:—Java Runtime Environment (Java运行时环境) JVM:Java Virtual Ma ...

  10. JAVA-系统-【2】-创建自增长的用户表

    [2]创建数据库表  用户表 自增 1.用户表结构  数据excel 表1 2.创建表 Create table A_USER( id number primary key, username ) n ...