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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

dom4j使用总结

發布時間:2025/7/14 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 dom4j使用总结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.加載Xml

從文件加載

SAXReader reader = new SAXReader();String filePath = "/xmlfile/" + fileName + ".xml";Document document = null;try {document = reader.read(ProcessXmlUtil.class.getResourceAsStream(filePath));} catch (DocumentException e) {logger.error("error:", e);}return document;

通過字符串轉換

Document document = DocumentHelper.parseText(xmlString);

2.驗證

/*** 通過XSD驗證xml的準確性** @param xsdFileName xsd路徑 要全路徑* @param xmlString xml文件* @return*/public static String validateXsd(String xsdFileName, String xmlString) {try {XMLErrorHandler handler = new XMLErrorHandler();//獲取基于 SAX 的解析器的實例SAXParserFactory factory = SAXParserFactory.newInstance();//解析器在解析時驗證 XML 內容。factory.setValidating(true);//指定由此代碼生成的解析器將提供對 XML 名稱空間的支持。factory.setNamespaceAware(true);//使用當前配置的工廠參數創建 SAXParser 的一個新實例。SAXParser parser = factory.newSAXParser();//創建一個讀取工具//獲取要校驗xml文檔實例Document document = DocumentHelper.parseText(xmlString);parser.setProperty("http://java.sun.com/xml/jaxp/properties/schemaLanguage","http://www.w3.org/2001/XMLSchema");parser.setProperty("http://java.sun.com/xml/jaxp/properties/schemaSource","file:" + xsdFileName);//創建一個SAXValidator校驗工具,并設置校驗工具的屬性SAXValidator validator = new SAXValidator(parser.getXMLReader());//設置校驗工具的錯誤處理器,當發生錯誤時,可以從處理器對象中得到錯誤信息。 validator.setErrorHandler(handler);//校驗 validator.validate(document);XMLWriter writer = new XMLWriter(OutputFormat.createPrettyPrint());if (handler.getErrors().hasContent()) {logger.error("XML文件通過XSD文件校驗失敗!");writer.write(handler.getErrors());String error = "";for (Node node : handler.getErrors().content()) {error += node.asXML() + System.getProperty("line.separator");}return error;} else {logger.info("XML文件通過XSD文件校驗成功!");}return "";} catch (Exception ex) {logger.error("XML文件通過XSD文件:" + xsdFileName + "檢驗失敗。\n原因: " + ex.getMessage());return ex.getMessage();}}

注意,驗證xsd的路徑名要是完整的全路徑,如e://xml/xsd/test.xsd

3.Xpath

<?xml version="1.0" encoding="utf-8" ?> <root><name value="張三"><address>福建省廈門市XXX</address></name> </root>

獲取值:福建省廈門市XXX

document.selectSingleNode("//name/address").getText();

獲取name的屬性value

document.selectSingleNode("//name/@value").getText();

命名空間的處理:當XML有命名空間時,Xpath的查詢也要加上命名空間,且只能查詢一個層級

Map map = new HashMap();map.put("ns", nameSpace);XPath x = newXmlDoc.createXPath("//ns:name");

這里只查詢一級name是有值的,但是如果想同時查詢name下面的address,則返回的是空

Map map = new HashMap();map.put("ns", nameSpace);XPath x = newXmlDoc.createXPath("//ns:name");x.setNamespaceURIs(map);Node node= (x.selectSingleNode(rootNode));//有值x = newXmlDoc.createXPath("//ns:name/address");Node node2= (x.selectSingleNode(rootNode));//值為空

如果想查詢address上的值,則必須在name節點上查詢,如

Map map = new HashMap();map.put("ns", nameSpace);XPath x = newXmlDoc.createXPath("//ns:name");x.setNamespaceURIs(map);Node node= (x.selectSingleNode(rootNode));//有值x = newXmlDoc.createXPath("//ns:address");x.setNamespaceURIs(map);Node node2= (x.selectSingleNode(node));//有值

所以想一次性用Xpath查詢,最好先把命名空間去掉

4.增加命名空間

Document newXmlDoc = DocumentHelper.createDocument();//頭部構建Element rootNode = newXmlDoc.addElement(strMsgModelCode);rootNode.addNamespace("", nameSpace);

第一個參數是空

5.在固定節點插入

?要循環遍歷節點,然后調用elements.add方法。這個真沒有.net的linq to xml方便。

List<Element> elements = rootNode.elements();int index = 0;for (Element element : elements) {index++;if ("name".equals(element.getName())) {elements.add(index, responseEle);break;}}

?

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的dom4j使用总结的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。