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;通過字符串轉(zhuǎn)換
Document document = DocumentHelper.parseText(xmlString);2.驗(yàn)證
/*** 通過XSD驗(yàn)證xml的準(zhǔn)確性** @param xsdFileName xsd路徑 要全路徑* @param xmlString xml文件* @return*/public static String validateXsd(String xsdFileName, String xmlString) {try {XMLErrorHandler handler = new XMLErrorHandler();//獲取基于 SAX 的解析器的實(shí)例SAXParserFactory factory = SAXParserFactory.newInstance();//解析器在解析時(shí)驗(yàn)證 XML 內(nèi)容。factory.setValidating(true);//指定由此代碼生成的解析器將提供對(duì) XML 名稱空間的支持。factory.setNamespaceAware(true);//使用當(dāng)前配置的工廠參數(shù)創(chuàng)建 SAXParser 的一個(gè)新實(shí)例。SAXParser parser = factory.newSAXParser();//創(chuàng)建一個(gè)讀取工具//獲取要校驗(yàn)xml文檔實(shí)例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);//創(chuàng)建一個(gè)SAXValidator校驗(yàn)工具,并設(shè)置校驗(yàn)工具的屬性SAXValidator validator = new SAXValidator(parser.getXMLReader());//設(shè)置校驗(yàn)工具的錯(cuò)誤處理器,當(dāng)發(fā)生錯(cuò)誤時(shí),可以從處理器對(duì)象中得到錯(cuò)誤信息。 validator.setErrorHandler(handler);//校驗(yàn) validator.validate(document);XMLWriter writer = new XMLWriter(OutputFormat.createPrettyPrint());if (handler.getErrors().hasContent()) {logger.error("XML文件通過XSD文件校驗(yàn)失敗!");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文件校驗(yàn)成功!");}return "";} catch (Exception ex) {logger.error("XML文件通過XSD文件:" + xsdFileName + "檢驗(yàn)失敗。\n原因: " + ex.getMessage());return ex.getMessage();}}注意,驗(yàn)證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();命名空間的處理:當(dāng)XML有命名空間時(shí),Xpath的查詢也要加上命名空間,且只能查詢一個(gè)層級(jí)
Map map = new HashMap();map.put("ns", nameSpace);XPath x = newXmlDoc.createXPath("//ns:name");這里只查詢一級(jí)name是有值的,但是如果想同時(shí)查詢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節(jié)點(diǎn)上查詢,如
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();//頭部構(gòu)建Element rootNode = newXmlDoc.addElement(strMsgModelCode);rootNode.addNamespace("", nameSpace);第一個(gè)參數(shù)是空
5.在固定節(jié)點(diǎn)插入
?要循環(huán)遍歷節(jié)點(diǎn),然后調(diào)用elements.add方法。這個(gè)真沒有.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;}}?
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
- 上一篇: HDU2552 三足鼎立 【数学推理】
- 下一篇: linux标准库的问题