Dom4J解析XML

原创 2016年08月31日 15:45:32
public class ParseXMLByDOM4J implements ParseXML
{
	public Person getPersonByID(String path, String id)
	{
		Person person = new Person();

		// 获取到XML文件首层元素所有内容
		Element users = readXMLByDOM4J(path);

		for (Iterator<?> i = users.elementIterator(); i.hasNext();)
		{
			Element user = (Element) i.next();
			if (StringUtils.equals(user.attribute("id").getText(), id))
			{
				person = buildPerson(person, user);
			}
		}

		return person;
	}

	public List<Person> getPersons(String path)
	{
		List<Person> personList = new ArrayList<Person>();
		Person person;

		// 获取到XML文件首层元素所有内容
		Element users = readXMLByDOM4J(path);
		for (Iterator<?> i = users.elementIterator(); i.hasNext();)
		{
			person = new Person();
			Element user = (Element) i.next();
			personList.add(buildPerson(person, user));
		}
		return personList;
	}

	private Element readXMLByDOM4J(String path)
	{
		File inputXml = new File(path);
		SAXReader saxReader = new SAXReader();

		Element result = null;
		try
		{
			Document document = (Document) saxReader.read(inputXml);
			result = document.getRootElement();
		}
		catch (DocumentException e)
		{
			e.printStackTrace();
		}
		return result;
	}

	private Person buildPerson(Person person, Element user)
	{
		for (Iterator<?> j = user.elementIterator(); j.hasNext();)
		{
			Element node = (Element) j.next();

			if (StringUtils.equals(node.getName(), "name"))
			{
				person.setName(node.getText());
			}

			if (StringUtils.equals(node.getName(), "age"))
			{
				person.setAge(Integer.parseInt(node.getText()));
			}

			if (StringUtils.equals(node.getName(), "hobbit"))
			{
				person.setHobbit(node.getText());
			}
		}
		return person;
	}
}


实际处理类

public class PersonServiceImpl implements PersonService
{
	private static final String XML_PATH = "src/main/resource/person.xml";
	private static ParseXML parser = new ParseXMLByDOM4J();

	public List<Person> getAllPerson()
	{
		return parser.getPersons(XML_PATH);
	}

	public void addPerson(Person person)
	{
		File inputXml = new File(XML_PATH);
		SAXReader saxReader = new SAXReader();

		try
		{
			Document document = (Document) saxReader.read(inputXml);
			Element rootElement = document.getRootElement();
			Element personEle = rootElement.addElement("person");
			personEle.addAttribute("id", String.valueOf(person.getId()));

			Element name = personEle.addElement("name");
			name.setText(person.getName());

			Element age = personEle.addElement("age");
			age.setText(String.valueOf(person.getAge()));

			Element hobbit = personEle.addElement("hobbit");
			hobbit.setText(person.getHobbit());

			saveXML(document);
		}
		catch (Exception e)
		{
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

	public void deletePersonByID(String id)
	{
		File inputXml = new File(XML_PATH);
		SAXReader saxReader = new SAXReader();

		try
		{
			Document document = (Document) saxReader.read(inputXml);
			Element rootElement = document.getRootElement();

			for (Iterator<?> i = rootElement.elementIterator(); i.hasNext();)
			{
				Element user = (Element) i.next();
				if (StringUtils.equals(user.attribute("id").getText(), id))
				{
					rootElement.remove(user);
					break;// 找到指定的id处理完毕后就跳出,节省性能
				}
			}
			saveXML(document);
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
	}


相关文章推荐

java dom4j解析xml

  • 2017年08月18日 15:40
  • 296KB
  • 下载

dom4j解析xml、javaweb三层架构初探

本篇博客主要讲述dom4j、XPath解析xml文档,以及javaweb开发程序的三层结构初探。...

dom4j解析xml和soap报文

  • 2017年09月14日 17:48
  • 17KB
  • 下载

XML的DOM4J的解析方式

  • 2012年05月08日 08:45
  • 3KB
  • 下载

Dom4J解析xml文档

1、DOM4J简介 DOM4J是 dom4j.org 出品的一个开源 XML 解析包。DOM4J应用于 Java 平台,采用了 Java 集合框架并完全支持 DOM,SAX 和 JAXP。 ...

dom4j进行xml文档的解析

  • 2013年01月20日 16:00
  • 5KB
  • 下载

XML解析-dom4j.jar-jdom.jar

  • 2013年12月28日 00:06
  • 423KB
  • 下载

xml文件的dom4j解析

jdom解析:http://blog.csdn.net/java4found/article/details/8665365 dom解析:http://blog.csdn.net/java4foun...

dom4j解析xml

  • 2014年01月15日 16:55
  • 171KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Dom4J解析XML
举报原因:
原因补充:

(最多只允许输入30个字)