XML Document常用工具类

org.w3c.dom.Document和org.dom4j.Document的工具类

<--org.w3c.dom.Document和org.dom4j.Document的maven依赖-->

   org.w3c
   dom
   2.3.0-jaxb-1.0.6

    
   org.dom4j
   dom4j
   2.1.0

 

package cn.wrapper;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.StringReader;
import java.io.StringWriter;
import java.io.UnsupportedEncodingException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.w3c.dom.NodeList;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
 
/**
 * Xml工具类.
 * 
 * @author qingwu
 * @date 2013-04-26
 */
public class XmlUtils {
	
	public static String XML_HEAD = "";
	public static String ROOT_BEIGN = "";
	public static String ROOT_END   = "";
 
	/**************************** dom4j begin ********************************/
 
	/**
	 * 字符串转org.dom4j.Document.
	 */
	public static org.dom4j.Document strToDom4jDoc(String xml) {
		try {
			return DocumentHelper.parseText(xml);
		} catch (DocumentException e) {
			throw new RuntimeException(e);
		}
	}
 
	/**
	 * 文件转org.dom4j.Document.
	 */
	public static org.dom4j.Document fileToDocument(String fileName) {
		InputStream is = XmlUtils.class.getResourceAsStream(fileName);
		SAXReader reader = new SAXReader();
		Document doc = null;
		try {
			doc = reader.read(is);
		} catch (DocumentException e) {
			throw new RuntimeException(e);
		} finally {
			try {
				is.close();
			} catch (IOException e) {
				throw new RuntimeException(e);
			}
		}
		return doc;
	}
 
	/**
	 * 输入流转org.dom4j.Document
	 */
	public static org.dom4j.Document inputStreamToDom4jDoc(InputStream is) {
		try {
			SAXReader reader = new SAXReader();
			return reader.read(is);
		} catch (DocumentException e) {
			throw new RuntimeException(e);
		}
	}
 
	/**
	 * org.dom4j.Document转字符串.
	 */
	public static String docToStr(org.dom4j.Document document) {
		return document.asXML();
	}
 
	/**************************** dom4j end ********************************/
 
	/**************************** w3c begin ********************************/
 
	/**
	 * 字符串转org.w3c.dom.Document.
	 */
	public static org.w3c.dom.Document strToW3cDoc(String xml) {
		DocumentBuilder builder;
		try {
			builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
			return builder.parse(new InputSource(new StringReader(xml)));
		} catch (ParserConfigurationException e) {
			throw new RuntimeException(e);
		} catch (SAXException e) {
			throw new RuntimeException(e);
		} catch (IOException e) {
			throw new RuntimeException(e);
		}
	}
 
	/**
	 * 输入流转org.w3c.dom.Document.
	 * 
	 * @param is
	 *            输入流
	 * @return org.dom4j.Document文档对象
	 * @author qingwu
	 * @date 2013-6-26 上午10:00:00
	 */
	public static org.w3c.dom.Document inputStreamToW3cDoc(InputStream is) {
		DocumentBuilder builder;
		try {
			builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
			return builder.parse(is);
		} catch (ParserConfigurationException e) {
			throw new RuntimeException(e);
		} catch (SAXException e) {
			throw new RuntimeException(e);
		} catch (IOException e) {
			throw new RuntimeException(e);
		}
	}
 
	/**
	 * org.w3c.dom.Document转字符串.
	 */
	public static String docToStr(org.w3c.dom.Document document) {
		String result = null;
 
		if (document != null) {
			StringWriter strWtr = new StringWriter();
			StreamResult strResult = new StreamResult(strWtr);
			TransformerFactory tfac = TransformerFactory.newInstance();
			try {
				javax.xml.transform.Transformer t = tfac.newTransformer();
				t.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
				t.setOutputProperty(OutputKeys.INDENT, "yes");
				t.setOutputProperty(OutputKeys.METHOD, "xml"); // xml, html,
				// text
				t.setOutputProperty(
						"{http://xml.apache.org/xslt}indent-amount", "4");
				t.transform(new DOMSource(document.getDocumentElement()),
						strResult);
			} catch (Exception e) {
				System.err.println("XML.toString(Document): " + e);
			}
			result = strResult.getWriter().toString();
			try {
				strWtr.close();
			} catch (IOException e) {
				throw new RuntimeException(e);
			}
		}
 
		return result;
	}
 
	/**
	 * 获得org.w3c.dom.Document唯一节点的文本值.
	 */
	public static String getNodeText(org.w3c.dom.Document doc, String nodeName) {
		return getNodeText(doc, nodeName, 0);
	}
 
	/**
	 * 获得org.w3c.dom.Document指定索引节点的文本值.
	 */
	public static String getNodeText(org.w3c.dom.Document doc, String nodeName,
			int index) {
		NodeList node = doc.getElementsByTagName(nodeName);
		if (node.getLength() > index && node.item(index) != null) {
			return node.item(index).getTextContent();
		}
		return null;
	}
 
	/**
	 * 获得org.w3c.dom.Node节点下指定nodeName节点的文本值.
	 */
	public static String getNodeText(org.w3c.dom.Node node, String nodeName) {
		org.w3c.dom.Node childNode = getChildNode(node, nodeName);
		if (childNode != null) {
			return childNode.getTextContent();
		}
		return null;
	}
 
	/**
	 * 获得org.w3c.dom.Node节点下指定nodeName节点.
	 */
	public static org.w3c.dom.Node getChildNode(org.w3c.dom.Node node,
			String nodeName) {
		NodeList list = node.getChildNodes();
		for (int i = 0; i < list.getLength(); i++) {
			if (list.item(i).getNodeName().equals(nodeName)) {
				return list.item(i);
			}
		}
		return null;
	}
 
	/**************************** w3c end ********************************/
 
	/**
	 * 格式化XML字符串(utf-8编码).
	 */
	public static String formatXml(String xmlMsg) {
		return formatXml(xmlMsg, null);
	}
 
	/**
	 * 格式化XML字符串.
	 */
	public static String formatXml(String xmlMsg, String encoding) {
		org.dom4j.Document _document = strToDom4jDoc(xmlMsg);
		String paramXML = "";
		if (encoding == null) {
			encoding = "utf-8";
		}
		try {
			OutputFormat format = OutputFormat.createPrettyPrint();
			format.setEncoding(encoding);
			ByteArrayOutputStream out = new ByteArrayOutputStream();
			XMLWriter writer = new XMLWriter(out, format);
			writer.write(_document);
			writer.flush();
			writer.close();
			paramXML = out.toString(format.getEncoding());
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return paramXML;
	}
 
}

 原文地址:https://blog.csdn.net/wq_tft/article/details/8979669

 

将XML Document 转为 Json 字符串输出

添加依赖


    org.jdom
    jdom
    1.1.3


    net.sf.json-lib
    json-lib
    2.3
    jdk15

XmlDocumentToJson.java

import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.InputStream;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

import org.jdom.Attribute;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;

import net.sf.json.JSONObject;

public class XmlDocumentToJson {

	 public static  String xml2JSON(String xml) {  
	        JSONObject obj = new JSONObject();  
	        try {  
	            InputStream is = new ByteArrayInputStream(xml.getBytes("utf-8"));  
	            SAXBuilder sb = new SAXBuilder();  
	            Document doc = sb.build(is);  
	            Element root = doc.getRootElement();  
	            obj.put(root.getName(), iterateElement(root));  
	            
	            return obj.toString();  
	        } catch (Exception e) {  
	            e.printStackTrace();  
	            return null;  
	        }  
	    }  

	    public static JSONObject xml2JSON(File file) {  
	        JSONObject obj = new JSONObject();  
	        
	        try {  
	            SAXBuilder sb = new SAXBuilder();  
	            Document doc = sb.build(file);  
	            
	            Element root = doc.getRootElement();             
	           
	            obj.put(root.getName(), iterateElement(root));  
	            return obj;  
	        } catch (Exception e) {  
	            e.printStackTrace();  
	            return null;  
	        }  
	    }  
	    
	    @SuppressWarnings({ "unchecked", "rawtypes" })  
	    private static Map  iterateElement(Element element) {  
	        List jiedian = element.getChildren();  
	        Element et = null;  
	        Map map = new HashMap();  
	        List list = null; 
	       //增加了对节点的处理
	        List attributes=element.getAttributes();
		    for(int i=0;i1){
	                	map.put(et.getName(), list);
	                }else{
	                	map.put(et.getName(), list.get(0));
	                }	                
             
	            } else { //子节点内 文本不为空 
	            	List temp_att=et.getAttributes();
	            	//若  子节点内有属性
	            	if(temp_att.size()!=0){
	            		Map childMap=new HashMap();
	             	    for(int j=0;j1){
	                    	map.put(et.getName(), list);
	                    }else{
	                    	map.put(et.getName(), list.get(0));
	                    }
	            	}
	            	
	            	
	            }  
	        }  
	        return map;  
	    }
		
		
 public static void main( String[] args ){
 		File myXml=new File("src\\main\\test.xml");
		String jsons=XmlDocumentToJson.xml2JSON(myXml).toString();
		//第一种  输出
		System.out.println(jsons );
		
		//格式化后输出
		FormatJson format=new FormatJson();
		System.out.println(format.formatJson(jsons));
 	}
}

FormatJson.java

/** 
 * 该类提供格式化JSON字符串的方法。 
 * 该类的方法formatJson将JSON字符串格式化,方便查看JSON数据。 
 * 

例如: *

JSON字符串:["yht","xzj","zwy"] *

格式化为: *

[ *

"yht", *

"xzj", *

"zwy" *

] * *

使用算法如下: *

对输入字符串,追个字符的遍历 *

1、获取当前字符。 *

2、如果当前字符是前方括号、前花括号做如下处理: *

(1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。 *

(2)打印:当前字符。 *

(3)前方括号、前花括号,的后面必须换行。打印:换行。 *

(4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。 *

(5)进行下一次循环。 *

3、如果当前字符是后方括号、后花括号做如下处理: *

(1)后方括号、后花括号,的前面必须换行。打印:换行。 *

(2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。 *

(3)打印:当前字符。 *

(4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。 *

(5)继续下一次循环。 *

4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。 *

5、打印:当前字符。 * * @author yanghaitao * @version [版本号, 2014年9月29日] */ public class FormatJson { /** * 单位缩进字符串。 */ private static String SPACE = " "; /** * 返回格式化JSON字符串。 * * @param json 未格式化的JSON字符串。 * @return 格式化的JSON字符串。 */ public String formatJson(String json){ StringBuffer result = new StringBuffer(); int length = json.length(); int number = 0; char key = 0; //遍历输入字符串。 for (int i = 0; i < length; i++){ //1、获取当前字符。 key = json.charAt(i); //2、如果当前字符是前方括号、前花括号做如下处理: if((key == '[') || (key == '{') ){ //(1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。 if((i - 1 > 0) && (json.charAt(i - 1) == ':')){ result.append('\n'); result.append(indent(number)); } //(2)打印:当前字符。 result.append(key); //(3)前方括号、前花括号,的后面必须换行。打印:换行。 result.append('\n'); //(4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。 number++; result.append(indent(number)); //(5)进行下一次循环。 continue; } //3、如果当前字符是后方括号、后花括号做如下处理: if((key == ']') || (key == '}') ){ //(1)后方括号、后花括号,的前面必须换行。打印:换行。 result.append('\n'); //(2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。 number--; result.append(indent(number)); //(3)打印:当前字符。 result.append(key); //(4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。 if(((i + 1) < length) && (json.charAt(i + 1) != ',')){ result.append('\n'); } //(5)继续下一次循环。 continue; } //4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。 if((key == ',')){ result.append(key); result.append('\n'); result.append(indent(number)); continue; } //5、打印:当前字符。 result.append(key); } return result.toString(); } /** * 返回指定次数的缩进字符串。每一次缩进三个空格,即SPACE。 * * @param number 缩进次数。 * @return 指定缩进次数的字符串。 */ private String indent(int number){ StringBuffer result = new StringBuffer(); for(int i = 0; i < number; i++){ result.append(SPACE); } return result.toString(); } }

 

 

你可能感兴趣的:(常用工具,xml,document)