MyBatis配置之properties属性详解

之前写了一篇《如何搭建MyBatis开发环境》,通过一个简单的实例讲解了关于搭建MyBatis的开发环境,这篇将详细讲解MyBatis的配置。

MyBatis配置文件的层次结构

<?xml version="1.0" encoding="UTF-8"?>
<!--配置-->
<configuration>
  <properties/><!--属性-->
  <settings/><!--设置-->
  <typeAliases/><!--类型命名-->
  <typeHandlers/><!--类型处理器-->
  <objectFactory/><!--对象工厂-->
  <plugins/><!--插件-->
  <environments><!--配置环境-->
    <environment><!--环境变量-->
      <transactionManager/><!--事务管理器-->
      <dataSource/><!--数据源-->
    </environment>
  </environments>
  <databaseIdProvider/><!--数据库厂商标识-->
  <mappers/><!--映射器-->
</configuration>

这是全部MyBatis的配置元素,看起来简单,但是层次顺序一定不能够颠倒。有些配置元素可以被省略不写,但是不影响层次顺序,后续的元素依次补上即可。

properties元素

properties是一个配置属性的元素,让我们能在配置文件的上下文中使用它。

MyBatis提供3种配置文件方式。

  • property子元素。
  • properties配置文件。
  • 程序参数传递。

property子元素

配置方法

<properties>
  <property name="driver" value="com.mysql.jdbc.Driver"/>
  <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
  <property name="username" value="root"/>
  <property name="password" value="123456"/>
</properties>

这样我们就可以在上下文使用已经配置好的属性值了。我们配置数据库时就可以按照如下代码进行配置。

<dataSource type="POOLED">
  <property name="driver" value="${driver}"/>
  <property name="url" value="${url}"/>
  <property name="username" value="${username}"/>
  <property name="password" value="${password}"/>
</dataSource>

其中${name}中的name值一定要与properties中的property子元素name属性的值相同。

properties配置文件

在实际项目中,更多的时候,是使用properties配置文件来配置属性值,这样可以方便开发者在多个配置文件中重复使用它们,也方便日后维护和随时修改。

<properties resource="jdbc.properties"/>

这样就引入了一个名为jdbc的properties文件。jdbc.properties代码如下

#数据库配置文件
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis
username=root
password=123456

注意:在jdbc.properties不能出现空格

程序参数传递

在实际工作中,数据库用户和密码是不允许以明文的形式存储在配置文件中的,而加密过后的数据库信息无法通过加密的字符串去连接数据库。这时就可以通过编码的形式去满足此场景。

假设在jdbc.properties文件中的username和password两个属性使用了加密的字符串,这个时候需要在生成SqlSessionFactory之前将它转化为明文,而系统已经提供了解密的方法decode(str)。

InputStream cfgStream = null;
Reader cfgReader = null;
InputStream proStream = null;
Reaader proReader = null;
Properties properties = null;
try {
  // 读入配置文件流
  cfgStream = Resource.getResourceAsStream("mybatis-config.xml");
  cfgReader = new InputStreamReader(cfgStream);
  // 读入属性文件
  proStream = Resource.getResourceAsStream("jdbc.properties");
  proReader = new InputStreamReader(proStream);
  properties = new Properties();
  properties.load(proReader);
  // 解密为明文
  properties.setProperty("username",decode(properties.getProperty("username")));
  properties.setProperty("password",decode(properties.getProperty("password")));
} catch(IOException ex) {
 Logger.getLogger(SqlSessionFactoryUtil.class.getName()).log(Level.SEVERE,null,ex)
}

synchronized(CLASS_LOCK) {
  if(sqlSessionFactory == null) {
    // 使用属性来创建SqlSessionFactory
    sqlSessionFactory = new SqlSessionFactoryBuilder().build(cfgReader,properties);
  }
}

使用总结

以上三种配置方式在MyBatis配置中可以同时出现,并且属性也会重复配置。所以三种方式是存在优先级的。

通过方法参数传递的属性具有最高优先级,resource/url属性中指定的配置文件次之,最低优先级的是properties属性中指定的属性。

在实际操作中,需要注意以下三点:

1、不要使用混合的方式,这样会使得管理混乱。

2、首选的方式是使用properties文件。

3、如果需要对其进行加密或其他加工以满足需求,不妨按示例的方法处理。这样做的好处是使得配置都来自于同一个配置文件,就不容易产生没有必要的歧义,也为日后统一管理提供了方便。

原创文章,作者:ZERO,如若转载,请注明出处:https://www.edu24.cn/course/mybatis-properties-cfg.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ZEROZERO
上一篇 2022年4月6日
下一篇 2022年4月20日

相关推荐

  • Webpack入门,常用loader

    babel-loader babel-loader用于处理ES6+并将其编译为ES5,它使开发者能够在工程中使用最新的语言特性,同时不必特别关注这些特性在不同平台的兼容问题。 在安…

    2022年11月23日
    764
  • 如何封装JDBC工具类读取properties配置文件连接数据库

    思路 之前已经写过一片《封装JDBC工具类,连接MySQL数据库》,讲解了如何封装JDBC工具类。但是在实际的应用中往往是把数据库连接的相关信息写在一个配置文件中,让程序自己去读取…

    2022年4月2日
    933
  • Angular环境搭建(Windows 10)

    目前前端开发正处于快速发展阶段,接触angular时,Angular 2刚刚发布,现在第五版也已经发布。由于刚开始没有系统的学习,导致工作中,经常捉襟见肘。现在把自己在工作中踩过的…

    2018年9月5日
    4.2K
  • Java自学之String类

    在实际项目开发中,String是一个必须使用的程序类,可以说是项目的核心组成类。在Java程序里所有的字符串都要求使用【’‘】进行定义,同时也可以利用【+】实现字符串的连接处理。 …

    2020年11月30日
    1.5K
  • Java自学之抽象类与接口

    面向对象程序设计中,类继承的主要作用的扩充已有类的功能。子类可以根据自己的需要选择是否要覆写父类中的方法,所以一个设计完善的父类是无法对子类做出任何强制性的覆写约定。为了解决这样的…

    2020年12月7日
    1.3K
  • STS插件mybatis-generator安装及使用

    断断续续学习Java也有好长时间了,没有师傅带,没有项目练手,学习超级慢,也很烦。视频、书籍翻看了一大推,还是没有目标。 相信滴水成海,外加条条大路通罗马,只要坚持,自己终能达成目…

    2019年12月27日
    2.4K
  • 外层有一个自适应高度的div,里面有两个div,一个高度固定300px,另一个怎么填满剩余的高度?

    可以设置外层自适应高度的容器为flex布局,利用flex-basis属性即可实现自动填满剩余高度;代码如下:

    2021年2月22日
    1.4K
  • MySQL数据库基础之视图及触发器相关知识点整理

    视图的操作 视图,本质上是一种虚拟表,其内容与真实的表相似,包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值形式存在。行和列数据来自自定义视图的查询所引用基本…

    2020年7月13日
    1.5K
  • Java自学之异常的捕获与处理

    在程序开发中,程序的编译与运行是两个不同的阶段,编译主要针对的是语法检测,而在程序运行时却有可能出现各种各样的错误导致程序中断执行,那么这些错误在Java中统一称为异常。 异常处理…

    2020年12月11日
    1.5K
  • MySQL数据库入门知识点整理

    数据库基本操作 1、创建数据库语句 数据库名称有以下几点要求 不能与已存在的数据库名称相同; 由字母、数字、下划线、@、$和#符号组成; 不能以数字及$符号开头; 标识符不能使用M…

    2020年7月7日
    1.6K