Java中XmlUtil工具类

XmlUtil工具类

整理一份用的比较多的XML与其他对象进行转换的工具类,里面每个方法都有注释

/**
 * XML工具类
 */
public class XmlUtil {

    private static Logger logger = Logger.getLogger(XmlUtil.class);
	public static final String ENCODING = "UTF-8";
	
	/**
	 * 
	 * @param xmlDoc
	 * @return
	 */
	public static String xmlToString(Object xmlDoc) {
		try {
//			if (xmlDoc != null && xmlDoc instanceof org.jdom.Document) {
//				XMLOutputter tXMLOutputter = new XMLOutputter();
//				tXMLOutputter.setEncoding(XmlUtil.ENCODING);
//				return tXMLOutputter.outputString((org.jdom.Document) xmlDoc);
//			} else if (xmlDoc != null && xmlDoc instanceof org.w3c.dom.Document) {
			if (xmlDoc != null && xmlDoc instanceof org.w3c.dom.Document) {
				Document doc = (org.w3c.dom.Document) xmlDoc;
				OutputFormat format = new OutputFormat(doc);
				format.setIndent(2);
				format.setEncoding(XmlUtil.ENCODING);
				Writer out = new StringWriter();
				XMLSerializer serializer = new XMLSerializer(out, format);
				serializer.serialize(doc);
				return out.toString();
			} else {
				return "";
			}
		} catch (Exception e) {
			logger.info("xml转换String出现错误",e);
			return "";
		}
	}
	  /** 
     * 将对象直接转换成String类型的 XML输出 
     *  
     * @param obj 
     * @return 
     */  
    public static String convertToXml(Object obj) {  
        // 创建输出流  
        StringWriter sw = new StringWriter();  
        try {  
            // 利用jdk中自带的转换类实现  
            JAXBContext context = JAXBContext.newInstance(obj.getClass());  
  
            Marshaller marshaller = context.createMarshaller();  
            // 格式化xml输出的格式  
            marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT,  
                    Boolean.TRUE);  
            // 将对象转换成输出流形式的xml  
            marshaller.marshal(obj, sw);  
        } catch (JAXBException e) {  
            logger.info("将对象直接转换成String类型的 XML出现错误",e);
        }  
        return sw.toString();  
    }  
  
    /** 
     * 将对象根据路径转换成xml文件 
     *  
     * @param obj 
     * @param path 
     * @return 
     */  
    public static void convertToXml(Object obj, String path) {  
        try {  
            // 利用jdk中自带的转换类实现  
            JAXBContext context = JAXBContext.newInstance(obj.getClass());  
  
            Marshaller marshaller = context.createMarshaller();  
            // 格式化xml输出的格式  
            marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT,  
                    Boolean.TRUE);  
            // 将对象转换成输出流形式的xml  
            // 创建输出流  
            FileWriter fw = null;  
            try {  
                fw = new FileWriter(path);  
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
            marshaller.marshal(obj, fw);  
        } catch (JAXBException e) {  
             logger.info("将对象根据路径转换成xml文件 出现错误",e);
        }  
    }  
  
    @SuppressWarnings("unchecked")  
    /** 
     * 将String类型的xml转换成对象 
     */  
    public static Object convertXmlStrToObject(Class clazz, String xmlStr) {  
        Object xmlObject = null;  
        try {  
            JAXBContext context = JAXBContext.newInstance(clazz);  
            // 进行将Xml转成对象的核心接口  
            Unmarshaller unmarshaller = context.createUnmarshaller();  
            StringReader sr = new StringReader(xmlStr);  
            xmlObject = unmarshaller.unmarshal(sr);  
        } catch (JAXBException e) {  
            logger.info("将String类型的xml转换成对象 出现错误",e);  
        }  
        return xmlObject;  
    }  
  
    @SuppressWarnings("unchecked")  
    /** 
     * 将file类型的xml转换成对象 
     */  
    public static Object convertXmlFileToObject(Class clazz, String xmlPath) {  
        Object xmlObject = null;  
        try {  
            JAXBContext context = JAXBContext.newInstance(clazz);  
            Unmarshaller unmarshaller = context.createUnmarshaller();  
            FileReader fr = null;  
            try {  
                fr = new FileReader(xmlPath);  
            } catch (FileNotFoundException e) {  
                e.printStackTrace();  
            }  
            xmlObject = unmarshaller.unmarshal(fr);  
        } catch (JAXBException e) {  
           logger.info("将file类型的xml转换成对象 出现错误",e);   
        }  
        return xmlObject;  
    }  
    
    /**
     * 将字符串转化为Document
     * @param xmlDoc
     * @return
     */
	public static org.w3c.dom.Document genXmlPEdor(String xmlDoc) {
		try {
			DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
			DocumentBuilder documentBuilder = factory.newDocumentBuilder();
			InputSource in = new InputSource(new StringReader(xmlDoc));
			return documentBuilder.parse(in);
		} catch (Exception e) {
			logger.info("将字符串转化为Document出现错误",e);   
			return null;
		}

	}
	

	/**
	 * get value of element
	 * 
	 * @param doc
	 *            org.w3c.dom.Document instance
	 * @param location
	 *            xpath (say: "//TXLife/TXLifeResponse/Policys")
	 * @return
	 */
	public static Element getElement(Document doc, String location) {
		try {
			XPathFactory pathFactory = XPathFactory.newInstance();
			XPath xpath = pathFactory.newXPath();
			XPathExpression pathExpression = xpath.compile(location);
			Object result = pathExpression.evaluate(doc, XPathConstants.NODESET);
			NodeList nodes = (NodeList) result;
			if (nodes != null && nodes.getLength() > 0) {
				Element element = (Element) nodes.item(0);
				return element;
			}
			return null;
		} catch (Exception e) {
			logger.info("得到element出现错误",e);   
			return null;
		}
	}
    /**
     * XML转为JDOM对象
     * 
     * @param XML
     * @return
     */
    public static org.jdom.Document XMLToJDom(String XML) {
		try {
		    String[] str = XML.split("[?]>");
		    if (str == null || str.length < 1) {
			return null;
		    }
		    String encoding = "GBK";
	
		    String[] encodingList = str[0].split("\"");
	
		    for (int i = 0; i < encodingList.length; i++) {
			if ("GBK".equals(encodingList[i].trim()) || "UTF-8".equals(encodingList[i].trim())) {
			    encoding = encodingList[i];
			    break;
			}
		    }
		    InputStream in_withcode = new java.io.ByteArrayInputStream(XML.getBytes(encoding));
		    // 文档对象
		    org.jdom.Document myDoc = null;
		    // 解析器
		    org.jdom.input.SAXBuilder sb = new org.jdom.input.SAXBuilder();
		    // 文档赋值
		    myDoc = sb.build(in_withcode);
		    return myDoc;
		} catch (Exception e) {
		    logger.info("XML转为JDOM对象出现错误",e);  
		    return null;
		}
    }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
XMLUtil 是一个工具类,主要用于读取 XML 配置文件并提供相应的操作方法。XMLUtil 的主要功能包括: 1. 读取 XML 配置文件:XMLUtil 可以读取指定路径下的 XML 配置文件,并将其解析成对应的 Java 对象或数据结构。这样,Java 应用程序就可以通过 XML 配置文件来获取应用程序的配置信息,而不需要硬编码到代码。 2. 解析 XML 配置文件:XMLUtil 可以解析 XML 配置文件的各种元素和属性,并将其转换为 Java 对象或数据结构。这样,Java 应用程序就可以通过 Java 对象或数据结构来访问 XML 配置文件的配置信息。 3. 提供操作方法:XMLUtil 还提供了一些常用的操作方法,比如获取指定元素或属性的值、添加或删除指定元素或属性等。这样,Java 应用程序就可以通过 XMLUtil 提供的方法来修改 XML 配置文件的配置信息。 XMLUtil 的好处包括: 1. 简化配置:通过 XML 配置文件,Java 应用程序可以将配置信息与代码分离,使得配置信息更易于管理和维护。而 XMLUtil 则可以更加方便地读取和解析 XML 配置文件,从而简化了配置的过程。 2. 提高灵活性:由于 XMLUtil 可以将 XML 配置文件解析成 Java 对象或数据结构,所以 Java 应用程序可以通过 Java 对象或数据结构来访问配置信息,从而提高了应用程序的灵活性。 3. 提高可维护性:通过 XMLUtil 提供的操作方法,Java 应用程序可以更加方便地修改 XML 配置文件的配置信息,从而提高了应用程序的可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农辰南

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值