zoukankan      html  css  js  c++  java
  • Spring使用外部的配置文件

    在使用Spring做web项目的时候,通常会使用到数据库的连接信息

    jdbcUrl   
    driverClass   
    username   
    password   

    那么应该如何使用这些属性呢?

    如在Spring中使用数据库连接池(数据源)

    你可能会这样写

    <!-- 配置数据库连接池 ComboPooledDataSource -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 基本的连接信息 -->
        <property name="jdbcUrl" value="jdbc:mysql:///mybatis"/>
        <property name="driverClass" value="com.mysql.jdbc.Driver"/>
        <property name="user" value="root"/>
        <property name="password" value="root"/>
        <!-- 一些管理的配置 -->
        <property name="initialPoolSize" value="3"></property>
        <property name="minPoolSize" value="3"></property>
        <property name="maxPoolSize" value="5"></property>
        <property name="acquireIncrement" value="3"></property>
        <property name="maxIdleTime" value="1800"></property>
    </bean>

    这是一种硬编码,如果数据库的连接环境变了,我们需要去beans.xml这个文件中进行修改,如果这个文件比较大,内容很多,找到这些信息就挺麻烦的。

    怎么办呢,将这些信息提取出来,放在单独一个属性文件中

    jdbc.properties,以后想改数据库连接环境的话改这个文件就可以了。

    jdbcUrl        = jdbc:mysql:///mybatis
    driverClass    = com.mysql.jdbc.Driver
    username       = root
    password       = root

    那么问题又来了,beans.xml文件需要读取jdbc.properties中的信息,我们需要告诉它去哪儿找jdbc.properties文件,怎么办呢?

    这就涉及到本讲讨论的问题:Spring使用外部的配置文件

    两种方式

    1.常用,较简单

    <!--加载外部的properties文件(方式一),用于解析${}形式的变量。-->
    <!--如果需要加载多个properties文件,就写在一起,之间使用逗号隔开。-->
    <context:property-placeholder location="classpath:jdbc.properties"/>

    2.

    <!-- 加载外部的properties文件(方式二) -->
    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <list>
                <!--可以有多个-->
                <value>classpath:jdbc.properties</value>
            </list>
        </property>
    </bean>

    有了此配置之后,数据源的配置就可以变为

    <!-- 加载外部的properties文件(方式一),用于解析${}形式的变量。 
            如果需要加载多个properties文件,就写在一起,之间使用逗号隔开。    -->
        <context:property-placeholder location="classpath:jdbc.properties"/>
    
    <!-- 配置数据库连接池 ComboPooledDataSource -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 基本的连接信息 -->
        <property name="jdbcUrl" value="${jdbcUrl}"/>
        <property name="driverClass" value="${driverClass}"/>
        <property name="user" value="${username}"/>
        <property name="password" value="${password}"/>
        <!-- 一些管理的配置 -->
        <property name="initialPoolSize" value="3"></property>
        <property name="minPoolSize" value="3"></property>
        <property name="maxPoolSize" value="5"></property>
        <property name="acquireIncrement" value="3"></property>
        <property name="maxIdleTime" value="1800"></property>
    </bean>
  • 相关阅读:
    字体图标
    css精灵图
    css定位
    浮动的清除
    浮动、版心布局
    css 盒子模型
    css三大特性、行高属性、权重
    JSP实现上传文件(或图片)到MySQL
    MySQL 错误. Packet for query is too large (***> 4194304). You can change......
    使用Servlet3.0提供的API实现文件上传到指定位置
  • 原文地址:https://www.cnblogs.com/winner-0715/p/5426532.html
Copyright © 2011-2022 走看看