日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

java builder.parse_JAVA之DocumentBuilder生成解析XML

發(fā)布時間:2024/4/13 asp.net 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java builder.parse_JAVA之DocumentBuilder生成解析XML 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1.創(chuàng)建DocumentBuilderFactory

DocumentBuilderFactory是用于創(chuàng)建DOM模式的解析器對象 , DocumentBuilderFactory是一個抽象工廠類,它提供了一個newInstance方法 ,這個方法會根據(jù)本地平臺默認(rèn)安裝的解析器,自動創(chuàng)建一個工廠的對象并返回。

/**

* DOM模式的解析器對象

* @return

* @throws ParserConfigurationException

*/

public static DocumentBuilder newDocumentBuilder() throws ParserConfigurationException {

DocumentBuilderFactory documentBuilderFactory = DocumentBuilderFactory.newInstance();

documentBuilderFactory.setFeature("http://apache.org/xml/features/disallow-doctype-decl", true);

documentBuilderFactory.setFeature("http://xml.org/sax/features/external-general-entities", false);

documentBuilderFactory.setFeature("http://xml.org/sax/features/external-parameter-entities", false);

documentBuilderFactory.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd", false);

documentBuilderFactory.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true);

documentBuilderFactory.setXIncludeAware(false);

documentBuilderFactory.setExpandEntityReferences(false);

// 調(diào)用工廠對象的newDocumentBuilder方法得到 DOM 解析器對象。

return documentBuilderFactory.newDocumentBuilder();

}

2.解析XML文件,代碼里面都有注釋

public static void reader() throws ParserConfigurationException, SAXException, IOException {

DocumentBuilder documentBuilder = XmlUtil.newDocumentBuilder();

// InputStream is = new FileInputStream(new File("file.xml"));

String strXML = "Empire BurlesqueHide your heart";

InputStream is = new ByteArrayInputStream(strXML.getBytes("UTF-8"));

// 調(diào)用 DOM 解析器對象的 parse() 方法解析 XML 文檔,得到代表整個文檔的 Document 對象,進(jìn)行可以利用DOM特性對整個XML文檔進(jìn)行操作了。

Document document = documentBuilder.parse(is);

// 得到 XML 文檔的根節(jié)點

Element rootElement = document.getDocumentElement();

rootElement.normalize();

// 得到節(jié)點的子節(jié)點

NodeList catalogs = rootElement.getChildNodes();

if (catalogs != null) {

for (int i = 0; i < catalogs.getLength(); i++) {

Node cd = catalogs.item(i);

// TEXT_NODE 說明該節(jié)點是文本節(jié)點

// ELEMENT_NODE 說明該節(jié)點是個元素節(jié)點

if (cd.getNodeType() == Node.ELEMENT_NODE) {

// 取得節(jié)點的屬性值

// String email = user.getAttributes().getNamedItem("attr").getNodeValue();

// 輪循子節(jié)點

for (Node node = cd.getFirstChild(); node != null; node = node.getNextSibling()) {

if (node.getNodeType() == Node.ELEMENT_NODE) {

if (node.getNodeName().equals("TITLE")) {

Node titleNode = node.getFirstChild();

// 如果是文本

if (titleNode.getNodeType() == Node.TEXT_NODE) {

System.out.println("節(jié)點的值:" + titleNode.getNodeValue());

}

}

}

}

}

}

}

}

3.創(chuàng)建XML

public static void writer() throws ParserConfigurationException, TransformerException {

Map maps = new HashMap(16);

maps.put("ARTIST", "Bonnie Tyler");

maps.put("TITLE", "Hide your heart");

maps.put("COUNTRY", "UK");

Document document = XmlUtil.newDocument();

// 根節(jié)點

Element rootEmement = document.createElement("CATALOGS");

document.appendChild(rootEmement);

Element cdElement = document.createElement("CD");

rootEmement.appendChild(cdElement);

for (String key : maps.keySet()) {

Element field = document.createElement(key);

field.appendChild(document.createTextNode(maps.get(key)));

cdElement.appendChild(field);

}

// 設(shè)置XML聲明中standalone為yes,即沒有dtd和schema作為該XML的說明文檔,且不顯示該屬性

document.setXmlStandalone(true);

// 開始生成XML文件

TransformerFactory tf = TransformerFactory.newInstance();

Transformer transformer = tf.newTransformer();

DOMSource source = new DOMSource(document);

transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");

transformer.setOutputProperty(OutputKeys.INDENT, "yes");

StringWriter writer = new StringWriter();

StreamResult result = new StreamResult(writer);

// 生成到文件里

// StreamResult result = new StreamResult("D:\\cds.xml");

transformer.transform(source, result);

String output = writer.getBuffer().toString(); // .replaceAll("\n|\r", "");

try {

writer.close();

}

catch (Exception ex) {

}

System.out.println(output);

}

總結(jié)

以上是生活随笔為你收集整理的java builder.parse_JAVA之DocumentBuilder生成解析XML的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。