zoukankan      html  css  js  c++  java
  • Spring利用propertyConfigurer类 读取.property数据库配置文件

    1.Spring的框架中,org.springframework.beans.factory.config.PropertyPlaceholderConfigurer类能够将.properties(key/value形式)文件里
    一些动态设定的值(value)。在XML中替换为占位该键($key$)的值。
    .properties文件能够依据客户需求。自己定义一些相关的參数。这种设计可提供程序的灵活性。

    2.在Spring中,使用PropertyPlaceholderConfigurer能够在XML配置文件里增加外部属性文件,当然也能够指定外部文件的编码,如:
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location">
          <value>conf/sqlmap/jdbc.properties</value>
        </property>
         <property name="fileEncoding">
           <value>UTF-8</value>
         </property>
    </bean>
    当然也能够引入多个属性文件,如:
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
       <property name="locations">
        <list>
         <value>/WEB-INF/mail.properties</value>   
         <value>classpath: conf/sqlmap/jdbc.properties</value>//注意这两种value值的写法
        </list>
       </property>
    </bean>

    主要的用法是:
    Xml代码
    <bean id="propertyConfigurerForAnalysis" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location">
            <value>classpath:/spring/include/dbQuery.properties</value>
        </property>
        <property name="fileEncoding">
           <value>UTF-8</value>
         </property>
    </bean>

    当中classpath是引用src文件夹下的文件写法。
    当存在多个Properties文件时。配置就需使用locations了:
    Xml代码
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
           <list>
              <value>classpath:/spring/include/jdbc-parms.properties</value>
              <value>classpath:/spring/include/base-config.properties</value>
              <value>classpath*:config/jdbc.properties</value>
            </list>
        </property>
    </bean>


    接下来我们要使用多个PropertyPlaceholderConfigurer来分散配置,达到整合多project下的多个分散的Properties文件,其配置例如以下
    Xml代码
    <bean id="propertyConfigurerForProject1" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="order" value="1" />
        <property name="ignoreUnresolvablePlaceholders" value="true" />
        <property name="location">
           <value>classpath:/spring/include/dbQuery.properties</value>
        </property>
    </bean>


    Xml代码
    <bean id="propertyConfigurerForProject2" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="order" value="2" />
        <property name="ignoreUnresolvablePlaceholders" value="true" />
        <property name="locations">
          <list>
            <value>classpath:/spring/include/jdbc-parms.properties</value>
            <value>classpath:/spring/include/base-config.properties</value>
          </list>
        </property>
    </bean>
    当中order属性代表其载入顺序。
    而ignoreUnresolvablePlaceholders为是否忽略不可解析的Placeholder。如配置了多个PropertyPlaceholderConfigurer,则需设置为true

    3.譬如。jdbc.properties的内容为:
    jdbc.driverClassName=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost/mysqldb?

    useUnicode=true&amp;characterEncoding=UTF-8&amp;zeroDateTimeBehavior=round;
    jdbc.username=root
    jdbc.password=123456

    4.那么在spring配置文件里,我们就能够这样写:
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
       <property name="locations">
        <list>
         <value>classpath: conf/sqlmap/jdbc.properties </value>
        </list>
       </property>
    </bean>

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
       <property name="driverClassName" value="${jdbc.driverClassName}" />
       <property name="url" value="${jdbc.url}" />
       <property name="username" value="${jdbc.username}" />
       <property name="password" value="${jdbc.password}" />
    </bean>

    5.这样。一个简单的数据源就设置完成了。

    能够看出:PropertyPlaceholderConfigurer起的作用就是将占位符指向的数据库配置信息放在bean中定义的工具。

  • 相关阅读:
    挖矿病毒入侵-分析总结
    Linux查看包依赖关系的神器-repoquery分享
    Elasticsearch 字段为空(null)记录查询
    Python 导数 Elasticsearch 元数据到CSV
    基于docker快速构建MySQL主从复制环境
    Redis环境简单部署(集群/双机)
    FTP 脚本 to Shell脚本&bat脚本&python脚本
    专用服务器模式&共享服务器模式
    CentOS 7安装部署ELK 6.2.4-SUCCESS
    zabbix 数据库迁移变更
  • 原文地址:https://www.cnblogs.com/jzssuanfa/p/7246207.html
Copyright © 2011-2022 走看看