简介
- 可扩展标记语言
- 特征
- XML与平台无关 ,是一门独立的标记语言
- XML具有自我描述性
- 作用
- 网络数据传输
- 数据存储
- 配置文件
语法格式
<?xml version="1.0" encoding="UTF-8"?>
- 标记
- XML文档,由标记组成
- 语法:
- 开始标记:<标记名称>
- 结束标记:</标记名称>
- 标记名称规则:
- 名称可以包含字母、数字以及其他字符
- 名称不能以数字或者标点符号开始
- 名称不能以字符"xml"(或"XML")开始
- 名称不能包含空格,不能包含冒号(:)
- 名称区分大小写
- 开始标记与结束标记之间,是标记的内容
- 一个XML文档中,必须有且仅有一个根标记
- 标记可以嵌套,但是不允许交叉
- 标记名称允许重复
- 正例
<names>
<name>张三</name>
<name>李四</name>
</names>
<name>张三</name>
<name>李四</name>
- CDATA
- CDATA 是不应该由 XML 解析器解析的文本数据
例如:"<“和”&"在 XML 元素中都是非法的 - CDATA部分的所有内容都会被解析器忽略
- CDATA 部分由"<![CDATA["开始,由"]]>"结束
Java解析XML
- SAX解析
- 解析方式是事件驱动机制
- SAX解析器,逐行读取XML文件解析,每当解析到一个标签的开始/结束/内容/属性时,触发事件.
- 我们可以编写程序在这些事件发生时,进行相应的处理.
- 分析能够立即开始,而不是等待所有的数据被处理
- 逐行加载,节省内存.有助于解析大于系统内存的文档
- 有时不必解析整个文档,它可以在某个条件得到满足时停止解析.
- 单向解析,无法定位文档层次,无法同时访问同一文档的不同部分数据(因为逐
行解析,当解析第n行是,第n-1行已经被释放了,无法在进行操作了). - 无法得 知事件发生时元素的层次,只能自己维护节点的父/子关系。
- 只 读解析方式,无法修改XML文档的内容.
- DOM解析
- 是用与平台和语言无关的方式表示XML文档的官方W3C标准,分析该结构通常需要加载整个
文档和内存中建立文档树模型.程序员可以通过操作文档树,来完成数据的获取修改删除等.
- 文档在内存中加载,允许对数据和结构做出更改.
- 访问是双向的,可以在任何时候在树中双向解析数据。
- JDOM解析
- 目的是成为Java特定文档模型,它简化与XML的交互并且比使用DOM实现更快。由于是第一个Java特定模型,JDOM一直得到大力推广和促进。
- JDOM文档声明其目的是“使用20% (或更少)的精力解决80% (或更多) Java/XML问 题"
(根据学习曲线假定为20%)
- 使用具体类而不是接口,简化了DOM的API。2.
- 大量使用了Java集合类,方便了Java开发人员。
- 没有较好的灵活性。
- 性能不是那么优异。
- DOM4J解析
- 它是JDOM的一种智能分支。 它合并了许多超出基本XML文档表示的功能,包括集成的XPath支持、XML schema支持 以及用于大文档或流化文档的基于事件的处理。它还提供了构建文档表示的选项,DOM4J是一个非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件。如今你可以看到越来越多的Java软件都在使用DOM4J来读写XML。
- 目前许多开源项目中大量采用DOM4J,例如:Hi bernate
DOM4J解析XML
- 步骤:
- 引入jar文件 dom4j .jar
- 创建一个指向XML文件的输入流
FileInputstream fis = new FileInputstream(“xm1文件 的地址”); - 创建一个XML读取工具对象
SAXReader sr = new SAXReaderO; - 使用读取 工具对象,读取XML文档的输入流,并得到文档对象
Document doc = sr . read(fis); - 通过文档对象, 获取XML文档中的根元素对象
Element root = doc . getRootElement();
- 解析本地XML文件
FileInputStream fis = new FileInputStream("Demo1.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(fis);
Element root = doc.getRootElement();
String name = root.getName();
System.out.println(name);
fis.close();
System.out.print("请输入电话号码:");
String phone = new Scanner(System.in).nextLine();
URL url = new URL("http://apis.juhe.cn/mobile/get?phone="+phone+"&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253");
URLConnection conn = url.openConnection();
InputStream is = conn.getInputStream();
SAXReader sr = new SAXReader();
Document doc = sr.read(is);
Element root = doc.getRootElement();
String code = root.elementText("resultcode");
if (code.equals("200")) {
Element result = root.element("result");
String province = result.elementText("province");
String city = result.elementText("city");
String areacode = result.elementText("areacode");
String zip = result.elementText("zip");
String company = result.elementText("company");
if (province.equals(city)) {
System.out.println("手机号码归属地:"+city);
}else {
System.out.println("省份:"+province);
System.out.println("城市:"+city);
}
System.out.println("区号:"+areacode);
System.out.println("邮编:"+zip);
System.out.println("运营商:"+company);
}else {
System.out.println("手机号码有误!");
}
XPATH解析XML
- 路径表达式
- 解析本地XML
FileInputStream fis = new FileInputStream("Demo1.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(fis);
List<Node> names = doc.selectNodes("//name");
for (int i = 0;i < names.size();i++) {
System.out.println(names.get(i).getName());
System.out.println(names.get(i).getText());
}
System.out.print("请输入电话号码:");
String phone = new Scanner(System.in).nextLine();
URL url = new URL("http://apis.juhe.cn/mobile/get?phone="+phone+"&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253");
URLConnection conn = url.openConnection();
InputStream is = conn.getInputStream();
SAXReader sr = new SAXReader();
Document doc = sr.read(is);
Node node = doc.selectSingleNode("//company");
System.out.println("运营商:"+node.getText());
Java生成XML
- 步骤:
- 通过文档帮助器(DocumentHelper) ,创建空的文档对象
Document doc = DocumentHelper . createDocument( ); - 通过文档对象,向其中添加根节点
Element root = doc . addElement(“根节点名称”); - 通过根节点对象root,丰富我们的子节点
Element e = root . addElement(“元素名称”); - 创建一个文件输出流,用于存储XML文件
FileOutputstream fos = new FileOutputstream(" 要存储的位置"); - 将文件输出流,转换为XML文档输出流
XMLWriter xw = new XMLWri ter(fos) ; - 写出文档
xw. write(doc) ; - 释放资源
xw. close();
Document doc = DocumentHelper.createDocument();
Element books = doc.addElement("books");
for (int i = 0;i < 100;i++) {
Element book = books.addElement("book");
Element name = book.addElement("name");
name.setText(i+"一本书");
Element info = book.addElement("info");
info.setText(i+"努力才有成功的希望");
book.addAttribute("id",100+i+"");
}
FileOutputStream fos = new FileOutputStream("BOOK.xml");
XMLWriter xw = new XMLWriter(fos);
xw.write(doc);
xw.close();
System.out.println("执行完毕");
XStream生成XML(需要导入XStream.jar)
- 步骤
- 创建XStream 对象
XStream x = new XStream(); - 修改类生成的节点名称 (默认节点名称为 包名.类名)
x.alias(“节点名称”,类名.class); - 传入对象 , 生成XML字符串
String xml字符串 = x.toXML(对象);
XStream x = new XStream();
x.alias("Person",Person.class);
String s = x.toXML(p);
public static void main(String[] args) {
Person p = new Person();
p.setName("张三");
p.setAge(22);
XStream x = new XStream();
x.alias("Person",Person.class);
String s = x.toXML(p);
System.out.println(s);
}
static class Person{
private String name;
private int age;
public Person() {
}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Person Person = (Person) o;
return age == Person.age &&
Objects.equals(name, Person.name);
}
@Override
public int hashCode() {
return Objects.hash(name, age);
}
}