Dom4j-读写xml
1.示例代码
Document document = DocumentHelper.createDocument();
// 增加命名空间
Namespace sopa12 = Namespace.get("soap12", "http://www.w3.org/2003/05/soap-envelope");
// 添加带命名空间的节点
Element eleSoap12 = document.addElement(new QName("Envelope", sopa12))
.addAttribute("xmlns:xsd", "http://www.w3.org/2001/XMLSchema")
.addAttribute("xmlns:xsi", "http://www.w3.org/2001/XMLSchema-instance");
eleSoap12.addElement(new QName("Body", sopa12)).addElement("GetGeoIP", "http://www.webservicex.net/")
.addElement("IPAddress").addText("180.102.21.198");
//节点添加xmlns属性
addElement("GetGeoIP", "http://www.webservicex.net/")
// dom转xml string
String requestContent = document.asXML();
//生成的xml文件
<?xml version="1.0" encoding="UTF-8"?>
<soap12:Envelope xmlns:soap12="http://www.w3.org/2003/05/soap-envelope" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<soap12:Body>
<GetGeoIP xmlns="http://www.webservicex.net/">
<IPAddress>180.102.21.198</IPAddress>
</GetGeoIP>
</soap12:Body>
</soap12:Envelope>
2. 解析XML
2.1 逐层解析
//string 转 dom, 字符串转xml
Document document = DocumentHelper.parseText(text);
//读取xml文件
SAXReader reader = new SAXReader();
Document document = reader.read(new File("d:/skills.xml"));
//根节点
Element root = document.getRootElement();
//子节点,elements
Element skill = root.element("skill");
//获取属性
Attribute attr1 = skill.attribute("name");
//节点内容值
node.getTextTrim()
2.2 XPath-推荐
2.2.1 简单不带namespace
List<Node> list = document.selectNodes("//foo/bar"); //获取多个节点
Node node = document.selectSingleNode("//foo/bar/author"); //后去单个节点
第一种形式 /AAA/DDD/BBB: 表示一层一层的,AAA下面 DDD下面的BBB
第二种形式 //BBB: 表示和这个名称相同,表示只要名称是BBB,都得到
第三种形式 /*: 所有元素
第四种形式 BBB[1]: 表示第一个BBB元素
BBB[last()]:表示最后一个BBB元素
第五种形式 //BBB[@id]: 表示只要BBB元素上面有id属性,都得到
第六种形式 //BBB[@id='b1'] 表示元素名称是BBB,在BBB上面有id属性,并且id的属性值是b1
2.2.2 带命名空间的复杂xml
List<Node> nodeStatus = document.selectNodes("//*[local-name()='status']");
text += "status: " + nodeStatus.get(0).getText() + "\n";
2.3 复杂xml解析示例
SAXReader reader = new SAXReader();
Document document = reader.read(new File("C:/Users/z00316474/Desktop/s.xml"));
// 获取status值
Node nodeStatus = document.selectSingleNode("//*[local-name()='status']");
System.out.println("status: " + nodeStatus.getText());
// 获取keyId-第一种方法
Node nodekeyId1 = document.selectSingleNode("//*[local-name()='keyId']");
System.out.println("keyId1: " + nodekeyId1.getText());
// 获取keyId-第二种方法
Node nodekeyId2 = document.selectSingleNode("//*[namespace-uri()='drm:MultiDrmCommon/v1/schemas']");
System.out.println("keyId2: " + nodekeyId2.getText());
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<GetKeyAndSignalizationResponse xmlns="drm:KeyAndSignalization/v1/schemas" xmlns:ns2="drm:MultiDrmCommon/v1/schemas">
<status>OK</status>
<contentKey>
<ns2:keyId>acb3a0fa-1484-4870-bc10-0c052957772b</ns2:keyId>
<ns2:key>aE3kbqlTKRP2HwqlZS+jBA==</ns2:key>
</contentKey>
<drmSignalization>
<ns2:hls>
<ns2:drmSystemId>adb41c24-2dbf-4a6d-958b-4457c0d27b95</ns2:drmSystemId>
<ns2:drmName>PRM</ns2:drmName>
<ns2:keyUri>http://www.nagra.com/key=31&prm=eyJjb250ZW50SWQiOiIzMSIsImtleUlkIjoiYWNiM2EwZmEtMTQ4NC00ODcwLWJjMTAtMGMwNTI5NTc3NzJiIn0</ns2:keyUri>
</ns2:hls>
</drmSignalization>
</GetKeyAndSignalizationResponse>
</soap:Body>
</soap:Envelope>
4. 官方链接
5. POM
<dependency>
<groupId>org.dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>2.0.1</version>
</dependency>
Dom4j-读写xml的更多相关文章
- Dom4j下载及使用Dom4j读写XML简介
sitinspring(如坐春风)原创,转载请注明作者及出处. 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4 ...
- Dom4j下载及使用Dom4j读写XML简介(转)
Dom4j下载及使用Dom4j读写XML简介 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:ht ...
- dom4j读写XML文档
dom4j 最常用最简单的用法(转) 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http:/ ...
- dom4j读写XML文件
XML文件格式: <?xml version="1.0" encoding="UTF-8"?> <company> <employ ...
- 【网络爬虫】【java】微博爬虫(四):数据处理——jsoup工具解析html、dom4j读写xml
之前提到过,对于简单的网页结构解析,可以直接通过观察法.手工写正则解析,可以做出来,比如网易微博.但是对于结构稍微复杂点的,比如新浪微博,如果还用正则,用眼睛一个个去找,未免太麻烦了. 本文介绍两个工 ...
- Dom4J读写xml
解析读取XML public static void main(String[] args) { //1获取SaxReader对象 SAXReader reader=new SAXReader(); ...
- Java实现——Dom4j读写XML文件
1. dom4j概述 解析DOM4J是一个开源XML解析包,采用了Java集合框架并完全支持DOM,SAX和JAXP. 最大的特色是使用了大量的接口,主要接口都在org.dom4j里定义. 2. do ...
- java dom4j 读写XML
<?xml version="1.0" encoding="UTF-8"?> <Configuration> <Config id ...
- 利用dom4j读写XML
public static HashMap<String, String> ReadConfig() { HashMap<String, String> map=new Has ...
- 转:在java中使用dom4j解析xml
JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...
随机推荐
- JVM体系结构之二:类加载器之2:JVM 自定义的类加载器的实现和使用
一.回顾一下jdk自带的类加载器: 1.java虚拟机自带的加载器 根类加载器(Bootstrap,c++实现) 扩展类加载器(Extension,java实现) 应用类加载器 ...
- 转载:Android Studio调试功能使用总结
这段时间一直在使用Intellij IDEA, 今天把调试区工具的使用方法记录于此. 先编译好要调试的程序. 1.设置断点 选定要设置断点的代码行,在行号的区域后面单击鼠标左键即可. 2.开启调试会话 ...
- PHPstorm 常用快捷键操作
1.ctrl+ N: 查找类 2.ctrl+ shift+ N: 全局搜索文件 ,优先文件名匹配的文件 3.ctrl + G: 定位行,跳转行 4.ctrl + F12: 显示当前页面类的所有方法 / ...
- JavaScript之JMap
在JavaScript中我们利用function类定义类在类的内部我们用var 定义私有变量 私有函数在类的内部我们用this 定义公有变量(1)定义一个类 function JMap() { var ...
- 基于OpenCV之视频读取,处理和显示框架的搭建(一)
主要包括以下内容: 1.使用的主要函数的说明. 2.两个实例:视频读取和显示.搭建视频读取和处理框架,调用canny函数提取边缘并显示. 3.一些注意事项和代码说明. 一.使用的主要函数 1.延时函数 ...
- Spring入门第二课
看代码 package logan.spring.study; public class HelloWorld { private String name; public void setName2( ...
- ASP.NET WebForm中JavaScript修改了页面上Label的值,如何在后台代码中获取
在用ASP.NET WebForm开发一个项目时,遇到如下的一个情况 页面上有一个Textbox控件,还有2个Label 控件. 当Textbox控件中的值更改时,两个Label控件上的值做相应的更改 ...
- 记录一次坎坷的linux内网渗透过程瞎折腾的坑
版权声明:本文为博主的原创文章,未经博主同意不得转载. 写在前面 每个人都有自己的思路和技巧,以前遇到一些linux的环境.这次找来一个站点来进行内网,写下自己的想法 目标环境 1.linux 2. ...
- JDK1.8的安装与卸载
Java的下载地址: https://www.java.com/zh_CN/download/ 下载完成后打开进入界面: 点击下一步, 上面也无需更改,也可自定义设置安装路径, 再次确认安装路径,点击 ...
- 【TMF eTOM】eTOM的概念和术语
eTOM的概念 为了有效地理解和使用eTOM业务流程框架,我们首先要理解构成eTOM的关键概念.这些概念使eTOM成为集成业务流程设计/评估与传统过程的一个非常有效的工具.在这些概念中使用了在本文中详 ...