J2EE基础之XML解析

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: J2EE基础之XML解析

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());

本期分享就到这里,下次在见😜😜😜😜😜

目录
相关文章
|
3月前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
3月前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
3月前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
3月前
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
92 0
|
3月前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
2月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
103 2
|
3月前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
89 0
|
3月前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
69 0
|
19天前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
|
19天前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象结构型模式比类结构型模式具有更大的灵活性。 结构型模式分为以下 7 种: • 代理模式 • 适配器模式 • 装饰者模式 • 桥接模式 • 外观模式 • 组合模式 • 享元模式
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析

推荐镜像

更多