• Spring 学习笔记 8. 尚硅谷_佟刚_Spring_使用外部属性文件


    1,配置数据源

    (1)添加驱动

    image

    (2)编写spring配置文件

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
            <property name="username" value="scott"></property>
            <property name="password" value="scott"></property>
            <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"></property>
            <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl"></property>
    </bean>

    (3)主方法

    package com.zsq;
    
    import java.sql.SQLException;
    import javax.sql.DataSource;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class Main {
    
        public static void main(String[] args) throws SQLException {
            // TODO Auto-generated method stub
            ApplicationContext ctx = new ClassPathXmlApplicationContext("beans-autowire.xml");
            DataSource dataSource = (DataSource) ctx.getBean("dataSource");
            System.out.println(dataSource.getConnection());
        }
    }

    结果:

    image

    这里已经证明可以正常连接到数据库。

    2,存在问题

    假如spring的配置文件里面有许多bean,这样文件大的话找到配置数据源的地方进行修改不方便。因此基本信息最好拿出来部署到属性文件里面最好。

    •在配置文件里配置 Bean 时, 有时需要在 Bean 的配置里混入系统部署的细节信息(例如: 文件路径, 数据源配置信息等). 而这些部署细节实际上需要和 Bean 配置相分离

    •Spring 提供了一个 PropertyPlaceholderConfigurer 的 BeanFactory 后置处理器, 这个处理器允许用户将 Bean 配置的部分内容外移到属性文件中. 可以在 Bean 配置文件里使用形式为 ${var} 的变量, PropertyPlaceholderConfigurer 从属性文件里加载属性, 并使用这些属性来替换变量.

    •Spring 还允许在属性文件中使用 ${propName},以实现属性之间的相互引用。

    配置步骤:

    (1)添加属性文件---db.properties,填写如下内容,但是这些内容如何和spring里面的相关联呢?

    image

    (2)Bean 配置文件里使用形式为 ${var} 的变量, PropertyPlaceholderConfigurer 从属性文件里加载属性, 并使用这些属性来替换变量.

    •Spring 2.5 之后: 可通过 <context:property-placeholder> 元素简化:

    –<beans> 中添加 context Schema 定义

    –在配置文件中加入如下配置:

        <!-- 导入属性文件 -->
        <context:property-placeholder location="classpath:db.properties"/>
        <!--使用外部文件属性  -->
        <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
            <property name="username" value="${username}"></property>
            <property name="password" value="${password}"></property>
            <property name="driverClassName" value="${driverClassName}"></property>
            <property name="url" value="${url}"></property>
        </bean>

    这个时候会报错,仔细检查没啥错误啊,反正我在测试的时候找了很长时间的原因。

    Exception in thread "main" java.sql.SQLException: ORA-01017: invalid username/password; logon denied

    后来我修改了配置文件和属性文件:

    image

    image

    此时才解决问题:

    image

  • 相关阅读:
    INFORMIX体系效能改善第一步
    Ubuntu判袂率不正常的一种复杂治理措施
    ubuntu8.04分区分配方案
    计算机启动更快的十五招
    理顺 JavaScript (13) 对象及 json
    获取指定地址的 JPG 图片 回复 "bangrj" 的问题
    理顺 JavaScript (14) constructor 与 instanceof
    理顺 JavaScript (9) Date 类
    用 API 提取、写入指定网站的 Cookie 回复 "bangrj" 的问题
    理顺 JavaScript (10) Math 类
  • 原文地址:https://www.cnblogs.com/yefengyu/p/5118609.html
Copyright © 2020-2023  润新知