dom4j解析xml,dom4j 将对象解析到xml文件中以流的方式输出到服务器

阅读更多
最近做流程项目用到了dom4j,于是就对dom4j进行了大概的学习。我做的流程项目是jbpm4的,实现的功能是将流程用到的表从mysql数据库中导出,通过dom4j解析成xml文件,导出到客户端,这是流程的导出;也可以将导出的流程xml文件导入到mysql数据库中。别的不多说,下面我通过一个例子总结我对dom4j的学习。
首先创建一个测试项目dom4jTest,在项目的src目录下面创建一个pojo:Person.java代码如下:
package com.lujinyong.dom4j;

/**
 * 
 * @Description: person类用来测试java反射在dom4j中的使用
 * @Author: lujinyong
 */
public class Person {
	private int id;// 用户id
	private String name;// 用户名称
	private String sex;// 性别
	private int age;// 年龄
	private String address;// 住址

	public Person(int id, String name, String sex, int age, String address) {
		this.id = id;
		this.name = name;
		this.sex = sex;
		this.age = age;
		this.address = address;
	}
       /**这里将setter和getter方法省略了*/
	//重新toString()方法
	@Override
	public String toString() {
		return "Person [id=" + id + ", name=" + name + ", sex=" + sex
				+ ", age=" + age + ", address=" + address + "]";
	}
}

下面是Map和Pojo之间转换的通用方法:MapPojoUtils.java作为工具类
package com.lujinyong.dom4j;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import org.apache.commons.beanutils.BeanUtils;
/**
 * 
 * @Description: map和pojo之间的转换
 * @Author: lujinyong
 */
public class MapPojoUtils {
	/**
	 * 将map转换成对应的Pojo 类
	 * @param 要转换成的对像
	 * @param map要转换的map
	 * @return
	 */
	public static Object map2Pojo(Object o, Map map) {
		Set> set = map.entrySet();
		for (Map.Entry entry : set) {
			if (entry.getValue() instanceof java.util.Date) {
				Date d = (Date) entry.getValue();
				map.put(entry.getKey(), MapPojoUtils.addDate(d, 0));
			}
		}
		BeanUtils bu = new BeanUtils();
		try {
			bu.populate(o, map);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return o;
	}

	/**
	 * 将pojo 对像转换成map
	 * @param obj
	 * @return
	 */
	public static Map pojo2Map(Object obj) {
		Map hashMap = new HashMap();
		Class c = obj.getClass();
		Field f[] = c.getDeclaredFields();
		Method method;
		String fieldName;
		for (Field field : f) {
			fieldName = field.getName();
			try {
				method = c.getDeclaredMethod("get"
						+ fieldName.substring(0, 1).toUpperCase()
						+ fieldName.substring(1));
				hashMap.put(fieldName, method.invoke(obj));
			} catch (Throwable e) {
				System.err.println(e);
			}
		}
		return hashMap;
	}
	/**
	 * 日期递增
	 * @param currentDate
	 * @param addNum
	 * @return
	 */
	public static Date addDate(Date currentDate,int addNum) {
		Calendar calender = Calendar.getInstance();
		calender.setTime(currentDate);
		calender.add(Calendar.DATE, addNum);
		Date date = calender.getTime();
		return date;
	}
}

因为实际项目中直接用的是数据库,但是在这个例子中为了简单我不是用数据库了,而是创建一个类来模拟数据库:MyDataSource.java
package com.lujinyong.dom4j;

import java.util.ArrayList;
import java.util.List;

/**
 * 
 * @Description:数据源,用了模拟数据库
 * @Author: lujinyong
 */
public class MyDataSource {
	/**
	 * 
	 * @Description: 获取10个person信息
	 * @Auther: lujinyong
	 */
	public static List getPersonList() {
		List list = new ArrayList();
		for (int i = 0; i < 10; i++) {
			Person p = new Person();
			p.setId(i);
			p.setName("张三" + i);
			p.setSex(((int) (Math.random() * 100)) % 2 == 0 ? "女" : "男");
			p.setAge(((int) (Math.random() * 100)));
			p.setAddress("中国");
			list.add(p);
		}
		return list;
	}
}

以上准备是为最重要的部分dom4j的解析做准备,关键类在下面:Dom4jTest.java
package com.lujinyong.dom4j;

import java.io.File;
import java.io.FileOutputStream;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.junit.Test;

/**
 * 
 * @Description: 该类测试dom4j的基本使用
 * @Author: lujinyong
 */
public class Dom4jTest {
	/**
	 * 
	 * @Description:将对象转成xml文件 
	 * @Auther: lujinyong
	 */
	@Test
	public void pojo2Xml(){
		/**1.创建document*/
		Document document = DocumentHelper.createDocument();
		/**2.添加根元素*/
		Element rootElement = document.addElement("root");
		/**3.用反射将person写到xml中*/
		List list = MyDataSource.getPersonList();
		for(Person person:list){
			rootElement = Dom4jTest.object2Element(rootElement, person, String.valueOf(person.getId()));
		}
		/**4.将document写到xml中并保存到服务器指定的目录中*/
		FileOutputStream xmlOut;
		try {
			xmlOut = new FileOutputStream(new File("d:/person.xml"));
			XMLWriter xmlWriter = new XMLWriter(xmlOut,OutputFormat.createPrettyPrint());
			xmlWriter.write(document);
			xmlWriter.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	/**
	 * 
	 * @Description:将对应的对象写到xml中 
	 * @Auther: lujinyong
	 */
	public static Element object2Element(Element root,Object obj,String id){
		try {
			//获取Document根元素
			Class clazz = obj.getClass();
			//获取对象名称
			String str = clazz.getName();
			String objName = str.substring(str.lastIndexOf(".")+1);
			//获取对象元素(以表名为标签的元素),不存在,则创建
			Element tableElement = root.element(objName);
			if(tableElement == null){
				tableElement = root.addElement(objName).addAttribute("id", id);
			}
			//创建一个节点元素
			Element nodeElement = tableElement.addElement("node").addAttribute("id", id);
			Field[] fields = clazz.getDeclaredFields();
			//遍历属性
			for(Field field :fields){
				/**拼接出属性对应的getter方法名*/
				//获取对象属性
				String fieldName = field.getName();
				StringBuilder sb = new StringBuilder();
				sb.append("get");
				sb.append(fieldName.substring(0,1).toUpperCase());
				if(fieldName.length()>1){
					sb.append(fieldName.substring(1));
				}
				String getMethodName = sb.toString();
				//反射method对象
				Method getMethod = obj.getClass().getMethod(getMethodName);
				//调用方法获取值
				Object fieldValue = getMethod.invoke(obj);
				//添加节点子元素元素
				Element fieldElement = nodeElement.addElement(fieldName).addAttribute(fieldName, fieldName);
				fieldElement.setText(fieldValue==null?"":fieldValue.toString());
			}
		} catch (Exception e) {
			throw new RuntimeException(e);
		}
		return root;
	}
	/**
	 * 
	 * @Description: 将xml中的数据转成Person对象
	 * @Auther: lujinyong
	 */
	@Test
	public void xml2Sql(){
		String filePath = "d:/person.xml";
		List list = new ArrayList();
		SAXReader reader = new SAXReader();
		try {
			/**1.读取xml文件,生成document*/
			Document document = reader.read(new File(filePath));
			/**2.将xml的流程节点信息保存到节点表中*/
			List nodeList = document.getRootElement().element("Person").elements("node");
			Map map = new HashMap();
			for(Element e : nodeList){
				List temp = e.elements();
				for(Element t : temp){
					map.put(t.getName(), t.getText());
				}
				Person person = (Person) MapPojoUtils.map2Pojo(new Person(), map);
				list.add(person);
			}
			for(Person p : list){
				System.out.println(p.toString());
			}
		} catch (DocumentException e) {
			e.printStackTrace();
		}
	}
}

运行pojo2Xml()方法,则在d盘中会创建一个person.xml文件,打开文件,文件内容如下:



 
   
      0
      张三0
     
      1
     
中国

   

   
      1
      张三1
     
      0
     
中国

   

   
      2
      张三2
     
      66
     
中国

   

   
      3
      张三3
     
      44
     
中国

   

   
      4
      张三4
     
      50
     
中国

   

   
      5
      张三5
     
      67
     
中国

   

   
      6
      张三6
     
      25
     
中国

   

   
      7
      张三7
     
      53
     
中国

   

   
      8
      张三8
     
      84
     
中国

   

   
      9
      张三9
     
      94
     
中国

   

   
      10
      张三10
     
      48
     
中国

   

 



运行xml2Sql()方法,则可以将d盘中创建的person.xml文件进行解析,并转成POJO,此时如果有数据库就可以将转成的POJO保存的数据库中了。
总结一下,该例子中用到的重要知识点:java的反射,dom4j解析。
还有一个比较实用的工具类Map和POJO之间的转化。

永久链接: http://kevin12.iteye.com/blog/1940281

你可能感兴趣的:(xml,mysql,jbpm,java,dom4j)