当前位置: 首页 > news >正文

java配置文件解析yml/xml/properties文件

XML

以mybatis.xml:获取所有Environment中的数据库并连接session为例

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;
import java.util.*;public static Map<String, SqlSession> openSessionOther(String resource){Map<String, SqlSession> sessionMap = new HashMap<>();try {InputStream inputStream = Resources.getResourceAsStream(resource);File configFile = new File(resource);DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();Document doc = dBuilder.parse(inputStream);doc.getDocumentElement().normalize();NodeList nList = doc.getElementsByTagName("environment");for (int temp = 1; temp < nList.getLength(); temp++) {Node nNode = nList.item(temp);if (nNode.getNodeType() == Node.ELEMENT_NODE) {Element eElement = (Element) nNode;SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream(resource), eElement.getAttribute("id"));sessionMap.put(eElement.getAttribute("id"), factory.openSession());log.debug("Environment id : " + eElement.getAttribute("id"));}}} catch (IOException| ParserConfigurationException | SAXException e) {e.printStackTrace();log.error("其他数据库连接异常!!!");throw new ExceptionInInitializerError(e);}return sessionMap;}

properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf8
jdbc.username=root
jdbc.password=123456

1.properties文件mybatis数据库配置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!--配置--><properties resource="jdbc.properties"><!--properties属性--><property name="database.driver" value="com.mysql.jdbc.Driver"/> <property name="database.url" value="jdbc:mysql://localhost:3306/chapter4"/><property name="database.username" value="root"/> <property name="database.password" value="123456"/> </properties><typeAliases><!-- 别名 --><typeAlias alias="Student" type="domain.Student"/> </typeAliases><!-- 数据库环境 --><environments default="development"><!--配置环境--><environment id="development"><!--环境变量--><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="${jdbc.driver}" /><property name="url" value="${jdbc.url}" /><property name="username" value="${jdbc.username}" /><property name="password" value="${jdbc.password}" /></dataSource></environment></environments>
<!--映射文件--><mappers><package name="com.learn.ssm.chapter4.mapper" /></mappers>
</configuration>

2.java读取

方式很多,获取文件流

public void readProperties1() throws IOException {//不加/会从当前包进行寻找,加上/会从src开始找InputStream inputStream = this.getClass().getResourceAsStream("jdbc.properties");Properties properties=new Properties();properties.load(inputStream);System.out.println("jdbc.driver="+properties.getProperty("jdbc.driver"));System.out.println("jdbc.url="+properties.getProperty("jdbc.url"));System.out.println("jdbc.username="+properties.getProperty("jdbc.username"));System.out.println("jdbc.password="+properties.getProperty("jdbc.password"));
}// import org.apache.ibatis.io.Resources;
public static void main(String[] args) {try {Properties properties = new Properties(Resources.getResourceAsProperties(""));} catch (IOException e) {e.printStackTrace();}}

YML解析

SnakeYAML
  • 优点:功能强大、灵活的API、广泛使用。
  • 缺点:相对复杂,需要处理更多的细节。

Jackson Dataformat YAML
  • 优点:与JSON处理库相同的API、广泛使用、与Jackson生态系统集成。
  • 缺点:相对复杂,需要在Jackson库的基础上进行配置和使用。
YAMLBeans
  • 优点:轻量级、简单易用。
  • 缺点:相对功能较少,适用于简单的YAML数据处理。
http://www.lryc.cn/news/364254.html

相关文章:

  • grpc接口调用
  • 通信技术振幅键控(ASK)调制与解调硬件实验
  • 自动化办公02 用openpyxl库操作excel.xlsx文件(新版本)
  • 用户反馈解决方案 —— 兔小巢构建反馈功能
  • git 下载失败
  • 力扣1438.绝对差不超过限制的最长连续子数组
  • 如何避免Python中默认参数带来的陷阱
  • 代码随想录算法训练营第五十天|198.打家劫舍、213.打家劫舍II、337.打家劫舍III
  • VB.net 进行CAD二次开发(二)
  • 安徽某高校数据挖掘作业6
  • CMakeLists.txt和Package.xml
  • Debian常用命令详解
  • 代码随想录算法训练营day29|491.递增子序列、46.全排列、47.全排列II
  • 【ARM Cache 与 MMU 系列文章 7.8 – ARMv8/v9 MMU Table 表分配原理及其代码实现 2】
  • SAP PP学习笔记17 - MTS(Make-to-Stock) 按库存生产(策略70)
  • 网页音频提取在线工具有哪些 网页音频提取在线工具下载
  • 【ARM Cache 系列文章 2.1 -- Cache PoP 及 PoDP 介绍】
  • 一文了解JVM面试篇(上)
  • C#WPF控件Textbox绑定浮点型数据限制小数位方法
  • mysql引入表名称的注意事项
  • C语言数据结构快速排序的非递归、归并排序、归并排序的非递归等的介绍
  • 学生成绩管理系统(大一大作业)
  • 数据结构:模拟栈
  • 02-2.3.6 顺序表和链表的比较
  • C++ : 模板初阶
  • FFA-Net:用于单图像去雾的特征融合注意力网络
  • 网工内推 | 联通公司,云计算售前,AWS认证优先
  • [Redis]Zset类型
  • 【云原生】Kubernetes----Ingress对外服务
  • 项目管理之maven svn