目录
1.XML解析是什么
XML解析(XML parsing)是指将XML文件中的数据解析并转换成计算机程序中可以处理的格式的过程。在XML中,数据被存储为标签和元素的组合,这些标签和元素本质上是一些文本字符串。XML解析器(XML parser)可以读取这些字符串并将它们转换为计算机程序能够使用的数据类型,如字符串、整数、浮点数、日期等。通过XML解析,程序可以方便地访问和操作XML文件中的数据。
2.为什么
优点
1. 可读性强XML文件使用标签来区分不同的元素,具有良好的可读性和可维护性,有助于开发人员理解和处理XML文件。
2. 结构化数据
XML提供了一种方式来描述数据的结构和层次结构,有助于开发人员在处理复杂数据结构时强制执行数据结构和约束条件。
3. 跨平台和通用性强
由于XML采用标准化格式,它具有跨平台和通用性强的优势,可以与不同平台、不同环境和不同开发语言进行交互。
4. 改善数据处理效率
在大量数据需要被处理时,使用XML解析器可以大大提高开发效率。XML解析器将XML文件解析为对象模型或者树状结构,可以轻松地对其进行访问、修改和转换,方便了数据的处理和管理。
💕💕💕总之,使用XML解析可以方便地读取和处理XML文件中的数据,并提高数据处理的效率和可靠性
文字的说服力俨然比不上代码,那么话不多说,我们直接看代码
3.三种配置位置及读取方式
以db_properties配置文件为例:
3.1 同一个包中
读取方式:demo1.class.getResourceAsStream("配置文件的名字");
// 1.同包下
InputStream asStream = demo1.class.getResourceAsStream("db.properties");//里面放配置文件的名字
//加载db.properties文件类容所对应的流
Properties p = new Properties();
p.load(asStream);
//打印db.properties文件的类容
System.out.println(p.getProperty("driver_Class"));//com.mysql.jdbc.Driver
运行结果为:
3.2同一个根目录下,不同包
读取方式:demo1.class.getResourceAsStream(" / 配置文件的名字");
注意:在写配置文件时,前面要加 /
//2.同一个根目录
InputStream asStream = demo1.class.getResourceAsStream("/db.properties");//里面放配置文件的名字
//加载db.properties文件类容所对应的流
Properties p = new Properties();
p.load(asStream);
//打印db.properties文件的类容
System.out.println(p.getProperty("driver_Class"));//com.mysql.jdbc.Driver
结果与上面那个一样
3.3安全位置--WEB-INF
--- 为什么说这是安全位置呢
-----因为在这个位置的配置文件是不会被泄露的,浏览器去搜索会报 404 的错误,所有它是安全位置,一般我们但是把配置文件放在这个位置,但是这个位置,在我们自己获取时,是要在Servlet里面执行代码,其它代码,与上面两个无异,看下方示例
package com.sy.xml;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/WEByinzi")
public class Webshenyan extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doPost(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//访问WEB-INF目录下的db.properties
InputStream is = request.getServletContext().getResourceAsStream("/WEB-INF/db.properties");
//加载db.properties文件类容所对应的流
Properties p = new Properties();
p.load(is);
//打印db.properties文件的类容
System.out.println(p.getProperty("driver_Class"));//com.mysql.jdbc.Driver
}
}
4.dom4J的使用
4.1 dom4J是什么
DOM4J是一个Java语言的XML解析库,它提供了一种方便、高效、灵活的方式来处理XML文档。 使用DOM4J可以轻松地读取和创建XML文档,支持XPath查询、修改和转换XML文档等功能 今天主要介绍 读取XML文档和XPth查询
四种常用方法
- selectNode 节点集合
- .selectSingleNode 单个节点
- getText 每个标签的内容
- attributeValue 属性
以students.xml为例
<?xml version="1.0" encoding="UTF-8"?> <students> <student sid="s001"> <name>小明</name> </student> <student sid="s002"> <name>小芳</name> </student> <student sid='s003'> <name>小王</name> </student> </students>
selectNode是一个集合,所以查询用foreach,用法还是比较简单的,都是固定的
5.XPth的使用
5.1XPth的作用:
XPath的作用十分广泛,可以用于XML文档的解析、数据抽取、处理和转换等场景,也可以用于Web开发、爬虫等多个领域。而且XPath可以非常快速地定位到一个或多个目标节点,而无需关心它们在文档中的具体位置,从而提高查找效率。
//XPth 查找ids002的名字
Element node2 = (Element) read.selectSingleNode("students/student[@sid='s002']/name");
System.out.println(node2.getText());
本期分享就到这里,下次在见😜😜😜😜😜