乐优商场项目day01——SpringBoot Java配置
一、配置的历史
在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配置的方式实现了数据库连接池,并且就连接成功了。