一.最最简单,最最通俗易懂,XMl解析

简介: 一.最最简单,最最通俗易懂,XMl解析

1.配置文件在jdbc中的作用

1.在Java中,JDBC(Java Database Connectivity)是一种用于连接和操作数据库的API。配置文件在JDBC中的作用主要是用来存储数据库连接的信息,如数据库的URL、驱动程序的类名、用户名和密码等。这些信息通常不应该硬编码到Java代码中,因为这样做会使代码变得非常不灵活,而且会增加维护的难度。相反,将这些信息保存在配置文件中,可以轻松地更改它们,从而避免了在更改连接信息时需要修改代码的麻烦。

2.配置文件通常用来指定JDBC驱动程序的加载和连接信息。在Java中,可以使用java.util.Properties类来读取配置文件。这个类提供了一种简单的方法来加载和解析属性文件,以获取应用程序所需的配置信息。调用Properties类的load()方法,可以从任何实现了java.io.InputStream接口的字节流中读取属性列表。然后,可以使用getProperty()方法获取配置信息,并将其传递给JDBC连接对象。

3.总之,配置文件在JDBC中极其重要,它可以方便地管理和维护连接信息,并使代码更加灵活和易于扩展。

2.读取不同位置下的配置文件

1.同包下读取配置文件

package com.niyin.xml2;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
 * 
 * @author 匿瘾
 *同包
 */
public class demo1 {
public static void main(String[] args) throws Exception {
//  通过类加载器加载配置文件
InputStream inputStream = demo1.class.getResourceAsStream("db.properties");
Properties p=new Properties();
p.load(inputStream);
System.out.println(p.getProperty("driver_Class"));
  System.out.println(p.getProperty("upass"));
  System.out.println(p.getProperty("url"));
}
}

被读取的配置文件

运行结果

2.根目录下读取配置文件

1.区别在与多了/,其它的与前面没有区别

package com.niyin.xml2;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
 * 
 * @author 匿瘾
 *同包
 */
public class demo1 {
public static void main(String[] args) throws Exception {
//  通过类加载器加载配置文件
InputStream inputStream = demo1.class.getResourceAsStream("/db.properties");
Properties p=new Properties();
p.load(inputStream);
System.out.println(p.getProperty("driver_Class"));
  System.out.println(p.getProperty("upass"));
  System.out.println(p.getProperty("url"));
}
}

3.读取安全目录WEB-INF下的配置文件

package com.niyin.xml2;
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;
/**
 * 
 * @author 匿瘾
 *
 */
@WebServlet("/Web‌infServlet")
public class Web‌infServlet extends HttpServlet {
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
doPost(request, response);
  }
  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
InputStream resourceAsStream = request.getServletContext().getResourceAsStream("/WEB-INF/lib/db.properties");
Properties p=new Properties();
p.load(resourceAsStream);
System.out.println(p.getProperty("driver_Class"));
  System.out.println(p.getProperty("upass"));
  System.out.println(p.getProperty("url"));
  }
}

运行结果

3.xml解析常用方法

1. 获取xml文件的内容DOM4J解析

xml,文件,接下来都会用它演示

package com.niyin.xml2;
import java.io.InputStream;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 *
 */
public class demo2 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
    System.out.println(doc.asXML());
  }
}

运行结果

2. 使用selectNodes获取student里的内容

package com.niyin.xml2;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 *
 */
public class demo2 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
    // System.out.println(doc.asXML());
    System.out.println(doc.asXML());
    List<Element> list = doc.selectNodes("/students/student");
//    List<Element> stuEles = doc.selectNodes("/students/student");
    System.out.println(list);
  }
}

运行结果

3.获取name标签内容,selectsingleNode

package com.niyin.xml2;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 *
 */
public class demo2 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
    // System.out.println(doc.asXML());
//    System.out.println(doc.asXML());
    List<Element> list = doc.selectNodes("/students/student");
    List<Element> stuEles = doc.selectNodes("/students/student");
    for (Element element : stuEles) {
//      System.out.println(element.asXML());
      Element nameELe = (Element) element.selectSingleNode("name");
      System.out.println(nameELe.asXML());
    }
  }
}

4.获得标签内容,getText

package com.niyin.xml2;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 *
 */
public class demo2 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
    // System.out.println(doc.asXML());
//    System.out.println(doc.asXML());
    List<Element> list = doc.selectNodes("/students/student");
    List<Element> stuEles = doc.selectNodes("/students/student");
    for (Element element : stuEles) {
//      System.out.println(element.asXML());
      Element nameELe = (Element) element.selectSingleNode("name");
//    System.out.println(nameELe.asXML());
System.out.println(nameELe.getText());
//    System.out.println(element.attributeValue("sid"));
    }
  }
}

运行结果

4.获取标签属性值,及学生学号,attributeValue

package com.niyin.xml2;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 *
 */
public class demo2 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
    // System.out.println(doc.asXML());
//    System.out.println(doc.asXML());
    List<Element> list = doc.selectNodes("/students/student");
    List<Element> stuEles = doc.selectNodes("/students/student");
    for (Element element : stuEles) {
//      System.out.println(element.asXML());
      Element nameELe = (Element) element.selectSingleNode("name");
//    System.out.println(nameELe.asXML());
//System.out.println(nameELe.getText());
    System.out.println(element.attributeValue("sid"));
    }
  }
}

运行结果

4.xml快速解析方法

1.普通方式获得sid对应的name

package com.niyin.xml2;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 * Xpath解析
 *
 */
public class demo3 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
    List<Element> stuEles = doc.selectNodes("/students/student");
    for (Element element : stuEles) {
if ("s002".equals(element.attributeValue("sid"))) {
  Element nameEle = (Element) element.selectSingleNode("name");
  System.out.println(nameEle.getText());
}
//xpath,解析
//Element nameEle = (Element) doc.selectSingleNode("/students/student[@sid='s002']/name");
//      System.out.println(nameEle.getText());
//    
    }
}
}

运行结果

2.通过Xpath方式获得

package com.niyin.xml2;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
 * 
 * @author 匿瘾
 * Xpath解析
 *
 */
public class demo3 {
  public static void main(String[] args) throws Exception {
    InputStream inputStream = demo2.class.getResourceAsStream("students.xml");
    SAXReader s = new SAXReader();
    Document doc = s.read(inputStream);
//    List<Element> stuEles = doc.selectNodes("/students/student");
//
//    for (Element element : stuEles) {
//if ("s002".equals(element.attributeValue("sid"))) {
//  Element nameEle = (Element) element.selectSingleNode("name");
//
//  System.out.println(nameEle.getText());
//  
//}
//xpath,解析
Element nameEle = (Element) doc.selectSingleNode("/students/student[@sid='s002']/name");
      System.out.println(nameEle.getText());
    }
}
//}

总结,两者,比较,xpath的方式更为简便,快捷。

目录
相关文章
|
7月前
|
存储 Java 文件存储
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— logback.xml 配置文件解析
本文解析了 `logback.xml` 配置文件的详细内容,包括日志输出格式、存储路径、控制台输出及日志级别等关键配置。通过定义 `LOG_PATTERN` 和 `FILE_PATH`,设置日志格式与存储路径;利用 `&lt;appender&gt;` 节点配置控制台和文件输出,支持日志滚动策略(如文件大小限制和保存时长);最后通过 `&lt;logger&gt;` 和 `&lt;root&gt;` 定义日志级别与输出方式。此配置适用于精细化管理日志输出,满足不同场景需求。
1813 1
|
7月前
|
XML JavaScript Android开发
【Android】网络技术知识总结之WebView,HttpURLConnection,OKHttp,XML的pull解析方式
本文总结了Android中几种常用的网络技术,包括WebView、HttpURLConnection、OKHttp和XML的Pull解析方式。每种技术都有其独特的特点和适用场景。理解并熟练运用这些技术,可以帮助开发者构建高效、可靠的网络应用程序。通过示例代码和详细解释,本文为开发者提供了实用的参考和指导。
203 15
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
207 0
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
7月前
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
691 29
|
7月前
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
208 4
|
7月前
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~