java builder.parse_JAVA之DocumentBuilder生成解析XML
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)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 读取 excel poi_ja
- 下一篇: asp.net ajax控件工具集 Au