天天看點

XML Document常用工具類org.w3c.dom.Document和org.dom4j.Document的工具類将XML Document 轉為 Json 字元串輸出

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

<--org.w3c.dom.Document和org.dom4j.Document的maven依賴-->
<dependency>
   <groupId>org.w3c</groupId>
   <artifactId>dom</artifactId>
   <version>2.3.0-jaxb-1.0.6</version>
</dependency>
    <dependency>
   <groupId>org.dom4j</groupId>
   <artifactId>dom4j</artifactId>
   <version>2.1.0</version>
</dependency>
           
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 = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>";
	public static String ROOT_BEIGN = "<root>";
	public static String ROOT_END   = "</root>";
 
	/**************************** 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 字元串輸出

添加依賴

<dependency>
    <groupId>org.jdom</groupId>
    <artifactId>jdom</artifactId>
    <version>1.1.3</version>
</dependency>
<dependency>
    <groupId>net.sf.json-lib</groupId>
    <artifactId>json-lib</artifactId>
    <version>2.3</version>
    <classifier>jdk15</classifier>
</dependency>
           

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<Attribute> attributes=element.getAttributes();
		    for(int i=0;i<attributes.size();i++){
		    	map.put(attributes.get(i).getName(), attributes.get(i).getValue());	      	
		    }
	        //周遊所有子節點
	        for (int i = 0; i < jiedian.size(); i++) {  
	            list = new LinkedList();  
	            et = (Element) jiedian.get(i);            
	            //若  子節點内文本為空
	            if (et.getTextTrim().equals("")) {  
	                if (et.getChildren().size() == 0)
	                	//若  沒有子節點則繼續
	                    continue;  
	                //若有  子節點  且  目前map有 本節點名稱
	                if (map.containsKey(et.getName())) {  
	                	list.add(map.get(et.getName()));
	                    //list = (List) map.get(et.getName());  
	                }  
	                list.add(iterateElement(et));  
	                if(list.size()>1){
	                	map.put(et.getName(), list);
	                }else{
	                	map.put(et.getName(), list.get(0));
	                }	                
             
	            } else { //子節點内 文本不為空 
	            	List<Attribute> temp_att=et.getAttributes();
	            	//若  子節點内有屬性
	            	if(temp_att.size()!=0){
	            		Map childMap=new HashMap();
	             	    for(int j=0;j<temp_att.size();j++){
	             	    	childMap.put(temp_att.get(j).getName(), temp_att.get(j).getValue());	      	
	             	    }
	             	   childMap.put("content",et.getTextTrim());
	             	   map.put(et.getName(), childMap);
	            	}else{
	            		if (map.containsKey(et.getName())) {  
	                        
	                    	try{
	                    		list = (List) map.get(et.getName()); 
	                    	}catch(Exception e){
	                    		list.add(map.get(et.getName()));
	                    	}
	                    }  
	                    list.add(et.getTextTrim());  
	                    if(list.size()>1){
	                    	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資料。 
 * <p>例如: 
 * <p>JSON字元串:["yht","xzj","zwy"] 
 * <p>格式化為: 
 * <p>[ 
 * <p>     "yht", 
 * <p>     "xzj", 
 * <p>     "zwy" 
 * <p>] 
 *  
 * <p>使用算法如下: 
 * <p>對輸入字元串,追個字元的周遊 
 * <p>1、擷取目前字元。 
 * <p>2、如果目前字元是前方括号、前花括号做如下處理: 
 * <p>(1)如果前面還有字元,并且字元為“:”,列印:換行和縮進字元字元串。 
 * <p>(2)列印:目前字元。 
 * <p>(3)前方括号、前花括号,的後面必須換行。列印:換行。 
 * <p>(4)每出現一次前方括号、前花括号;縮進次數增加一次。列印:新行縮進。 
 * <p>(5)進行下一次循環。 
 * <p>3、如果目前字元是後方括号、後花括号做如下處理: 
 * <p>(1)後方括号、後花括号,的前面必須換行。列印:換行。 
 * <p>(2)每出現一次後方括号、後花括号;縮進次數減少一次。列印:縮進。 
 * <p>(3)列印:目前字元。 
 * <p>(4)如果目前字元後面還有字元,并且字元不為“,”,列印:換行。 
 * <p>(5)繼續下一次循環。 
 * <p>4、如果目前字元是逗号。逗号後面換行,并縮進,不改變縮進次數。 
 * <p>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();  
    }  
}