當前位置:
首頁 >
dom4j使用总结
發布時間:2025/7/14
23
豆豆
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位技術專家共同創作,文字、視頻、音頻交互閱讀總結
- 上一篇: HDU2552 三足鼎立 【数学推理】
- 下一篇: linux标准库的问题