XML解析工具类

本文介绍了一种利用 Java 内省机制和反射技术简化 XML 文件解析的方法,通过具体示例展示了如何将 XML 数据映射到 Java Bean 对象,极大地提高了开发效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1.         由于以前在解析XML的时候,每次都要采用获取XML中的属性名来获取对应的值,每一个bean类都要写一个XML解析器。这将会使代码变得更加冗余,而没办法做到高度抽象。幸亏Java有自身的内省机制,Introspector与反射类似,主要是对Java Bean属性、方法等的一种处理方法。
  2.  
  3. package com.ibm.cn.xml;
  4.  
  5. import java.beans.BeanInfo;
  6. importjava.beans.Introspector;
  7. import java.beans.PropertyDescriptor;
  8. import java.io.File;
  9. importjava.lang.reflect.Method;
  10. import java.util.ArrayList;
  11. import java.util.Iterator;
  12. import java.util.List;
  13.  
  14. import org.dom4j.Document;
  15. import org.dom4j.Element;
  16. importorg.dom4j.io.SAXReader;
  17.  
  18.  
  19. /**
  20.  * XML解析工具类
  21.  * @author javamickey
  22.  * @date 2012-11-01
  23.  * @version 2.0
  24.  */
  25. public class ParsersUtil {
  26.  
  27.  
  28.                 /**
  29.                  * 通过XML文件名,来解析XML对象,此函数只针对XML中存在一个bean值的情况
  30.                  * @paramfileName XML文件名
  31.                  * @param typebean类名
  32.                  * @return 单个bean对象
  33.                  * @throwsException
  34.                  */
  35.                 public static Object parserXMLByFileName(StringfileName, Class<?> type)
  36.                                                 throws Exception {
  37.                                 Class<? extends Object>beanClass = Class.forName(type.getName());
  38.                                 Object bean =beanClass.newInstance();
  39.                                 File inputXml = new File(fileName);
  40.                                 SAXReader saxReader = new SAXReader();
  41.                                 try {
  42.                                                 Document document =saxReader.read(inputXml);
  43.                                                 Element element =document.getRootElement();
  44.                                                 BeanInfo beanInfo =Introspector.getBeanInfo(type);
  45.                                                 PropertyDescriptor[]propertyDescriptors = beanInfo.getPropertyDescriptors();
  46.                                                 for(PropertyDescriptor propertyDescriptor : propertyDescriptors) {
  47.                                                                 StringpropertyName = propertyDescriptor.getName();
  48.                                                                 for(Iterator<?> iterator = element.elementIterator(); iterator.hasNext();) {
  49.                                                                                 ElementemployeeElement = (Element) iterator.next();
  50.                                                                                 if(!propertyName.equals("class")) {
  51.                                                                                                 MethodreadMethod = propertyDescriptor.getWriteMethod();
  52.                                                                                                 Stringvalue = employeeElement.elementText(propertyName);
  53.                                                                                                 System.out.println("propertyName="+ propertyName + "value = " + value);
  54.                                                                                                 if(value != null) {
  55.                                                                                                                 readMethod.invoke(type,value);
  56.                                                                                                 }
  57.                                                                                 }
  58.                                                                 }
  59.                                                 }
  60.                                 } catch (Exception e) {
  61.                                                 e.printStackTrace();
  62.                                 }
  63.                                 return bean;
  64.                 }
  65.  
  66.                 /**
  67.                  * 通过XML文件名,来解析XML对象,此函数针对XML中存在一个或者多个bean值的情况
  68.                  * @paramfileName XML文件名
  69.                  * @param typebean类名
  70.                  * @return 返回一个List<bean>
  71.                  * @throwsException
  72.                  */
  73.                 public static List<Object>parserXMLByFileNameList(String fileName, Class<?> type)
  74.                                                 throws Exception {
  75.                                 Class<? extends Object>beanClass = Class.forName(type.getName());
  76.                                 List<Object> beanList = newArrayList<Object>();
  77.                                 File inputXml = new File(fileName);
  78.                                 SAXReader saxReader = newSAXReader();
  79.                                 try {
  80.                                                 Document document =saxReader.read(inputXml);
  81.                                                 Element element =document.getRootElement();
  82.                                                 BeanInfo beanInfo =Introspector.getBeanInfo(type);
  83.                                                 PropertyDescriptor[]propertyDescriptors = beanInfo.getPropertyDescriptors();
  84.                                                 for(Iterator<?> iterator = element.elementIterator(); iterator.hasNext();) {
  85.                                                                 Objectbean = beanClass.newInstance();
  86.                                                                 ElementemployeeElement = (Element) iterator.next();
  87.                                                                 for(PropertyDescriptor propertyDescriptor : propertyDescriptors) {
  88.                                                                                 StringpropertyName = propertyDescriptor.getName();
  89.                                                                                 if(!propertyName.equals("class")) {
  90.                                                                                                 MethodreadMethod = propertyDescriptor.getWriteMethod();
  91.                                                                                                 Stringvalue = employeeElement.elementText(propertyName);
  92.                                                                                                 System.out.println("propertyName="+ propertyName + "value = " + value);
  93.                                                                                                 if(value != null) {
  94.                                                                                                                 readMethod.invoke(bean,value);
  95.  
  96.                                                                                                 }
  97.                                                                                 }
  98.                                                                 }
  99.                                                                 beanList.add(bean);
  100.                                                 }
  101.  
  102.                                 } catch (Exception e) {
  103.                                                 e.printStackTrace();
  104.  
  105.                                 }
  106.                                 return beanList;
  107.                 }
  108.  
  109. }

package com.hexiang.utils; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NodeList; /** * 本类是专门解析XML文件的,主要用于为系统读取自己的配置文件时提供最方便的解析操作 * @author HX * */ public class XmlManager { /** * 得到某节点下某个属性的值 * @param element 要获取属性的节点 * @param attributeName 要取值的属性名称 * @return 要获取的属性的值 * @author HX_2010-01-12 */ public static String getAttribute( Element element, String attributeName ) { return element.getAttribute( attributeName ); } /** * 获取指定节点下的文本 * @param element 要获取文本的节点 * @return 指定节点下的文本 * @author HX_2010-01-12 */ public static String getText( Element element ) { return element.getFirstChild().getNodeValue(); } /** * 解析某个xml文件,并在内存中创建DOM树 * @param xmlFile 要解析XML文件 * @return 解析某个配置文件后的Document * @throws Exception xml文件不存在 */ public static Document parse( String xmlFile ) throws Exception { // 绑定XML文件,建造DOM树 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = dbf.newDocumentBuilder(); Document domTree = db.parse( xmlFile ); return domTree; } /** * 获得某节点下的某个子节点(指定子节点名称,和某个属性的值) * 即获取parentElement下名字叫childName,并且属性attributeName的值为attributeValue的子结点 * @param parentElement 要获取子节点的那个父节点 * @param childName 要获取的子节点名称 * @param attributeName 要指定的属性名称 * @param attributeValue 要指定的属性的值 * @return 符合条件的子节点 * @throws Exception 子结点不存在或有多个符合条件的子节点 * @author HX_2008-12-01 */ public static Element getChildElement( Element parentElement, String childName, String attributeName, String attributeValue ) throws Exception { NodeList list = parentElement.getElementsByTagName( childName ); int count = 0; Element curElement = null; for ( int i = 0 ; i < list.getLength() ; i ++ ) { Element child = ( Element )list.item( i ); String value = child.getAttribute( attributeName ); if ( true == value.equals( attributeValue ) ) { curElement =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值