一、配置的历史
在Spring3.0开始,Spring官方就已经开始推荐使用java配置来代替传统的xml配置了
Spring的历史:
-  
Spring1.0时代
在此时因为jdk1.5刚刚出来,注解开发还没有流行,这时候一切Spring配置都是xml格式(特别麻烦)
 -  
Spring2.0时代
Spring引入了注解开发,但是因为并不完善,因此并未完全替代xml,此时的程序员往往是把xml与注解进行结合(我们之前用的就是这样的。)
 -  
Spring3.0及以后
 -  
3.0以后Spring的注解已经非常完善了,因此Spring推荐大家使用完全的java配置来代替以前的xml,不过似乎在国内并未推广盛行。然后当SpringBoot来临,人们才慢慢认识到java配置的优雅。
 
二、java配置入门
我们来试试用Java配置实现一个连接池配置
  
在springboot里加一个config包,并创建一个类 JdbcConfiguration
在pom.xml中加入相关启动器,自动引入相关依赖
  
        <dependency>
            <groupId>com.github.drtrang</groupId>
            <artifactId>druid-spring-boot2-starter</artifactId>
            <version>1.1.10</version>
        </dependency>  
 添加一个资源文件,jdbc.properties
  
 写上连接属性(我这里以MySQL为例)
  
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/你数据库中的任意库
jdbc.username=root
jdbc.password=你数据库的密码  编写 JdbcConfiguration
  
@Configuration  //声明一个类是一个java配置类,相当于一个xml配置文件
 @PropertySource("classpath:jdbc.properties")  //读取资源文件
public class JdbcConfiguration {
    @Value("${jdbc.url}")
    private String url;
    @Value("${jdbc.driverClassName}")
    private String driverClassName;
    @Value("${jdbc.username}")
    private String username;
    @Value("${jdbc.password}")
    private String password;
    @Bean //把方法的返回值注入到spring容器,然后在任何地方都可以使用了
    public DataSource dataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setUrl(url);
        dataSource.setDriverClassName(driverClassName);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        return dataSource;
    }
}  
然后我们回到controller中看看能不能获取到连接。
以Debug形式运行引导类中的main方法
注意,你的数据库是要开启的。
运行启动成功之后,我们来访问一下http://localhost:8080/hello/show, idea会进入到断点。
 这时候我们来看看dataSource有没有数据。
  
这时候我们用Java配置的方式实现了数据库连接池,并且就连接成功了。

京公网安备 11010502036488号