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

2024-05-28 16:04

本文主要是介绍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数据处理。

这篇关于java配置文件解析yml/xml/properties文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1011029

相关文章

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

Java实现将Markdown转换为纯文本

《Java实现将Markdown转换为纯文本》这篇文章主要为大家详细介绍了两种在Java中实现Markdown转纯文本的主流方法,文中的示例代码讲解详细,大家可以根据需求选择适合的方案... 目录方法一:使用正则表达式(轻量级方案)方法二:使用 Flexmark-Java 库(专业方案)1. 添加依赖(Ma

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis

Spring Boot拦截器Interceptor与过滤器Filter详细教程(示例详解)

《SpringBoot拦截器Interceptor与过滤器Filter详细教程(示例详解)》本文详细介绍了SpringBoot中的拦截器(Interceptor)和过滤器(Filter),包括它们的... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)详细教程1. 概述1

SpringBoot利用dynamic-datasource-spring-boot-starter解决多数据源问题

《SpringBoot利用dynamic-datasource-spring-boot-starter解决多数据源问题》dynamic-datasource-spring-boot-starter是一... 目录概要整体架构构想操作步骤创建数据源切换数据源后续问题小结概要自己闲暇时间想实现一个多租户平台,

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Spring Cloud之注册中心Nacos的使用详解

《SpringCloud之注册中心Nacos的使用详解》本文介绍SpringCloudAlibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringClo... 目录Naacos服务注册/服务发现引⼊Spring Cloud Alibaba依赖引入Naco编程s依

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使