spring基于注解的IOC和DI配置
一 Spring原始注解主要是替代的配置
注解 | 说明 |
---|---|
@Component | 使用在类上用于实例化Bean |
@Controller | 使用在web层类上用于实例化Bean |
@Service | 使用在service层类上用于实例化Bean |
@Repository | 使用在dao层类上用于实例化Bean |
@Autowired | 使用在字段上用于根据类型依赖注入 |
@Qualifier | 结合@Autowired一起使用用于根据名称进行依赖注入 |
@Resource | 相当于@Autowired+@Qualifier,按照名称进行注入 |
@Value | 注入普通属性 |
@Scope | 标注Bean的作用范围 |
@PostConstruct | 使用在方法上标注该方法是Bean的初始化方法 |
@PreDestroy | 使用在方法上标注该方法是Bean的销毁方法 |
这些注解我们可以按照功能 , 大致分为以下四类 :
- 用于创建对象:作用和xml配置中的标签的作用是一样的
- 用于注入数据:作用和xml配置中的标签中的标签作用一样
- 用于改变作用范围:作用和xml配置中的标签的scope属性的作用一样
- 生命周期相关:作用和xml配置中的标签的init-method和destroy-method属性的作用是一样的
- 注意: value:指定bean的id。如果不指定value属性,默认bean的id是当前类的类名。首字母小写。
二 开启注解扫描
要想使用注解,必须在applicationContext.xml
中添加一段配置开启注解扫描
<!--配置注解扫描,扫描指定包下的注解-->
<context:component-scan base-package="包路径"></context:component-scan>
三 spring的新注解
@Configuration
作用:
用于指定当前类是一个spring配置类,当创建容器时会从该类上加载注解。获取容器时需要使用AnnotationApplicationContext(有@Configuration注解的类.class)。它的作用applicationContext.xml是一样的。当配置类作为AnnotationConfigApplicationContext对象创建的参数时,该注解可以不写。
属性:
value:用于指定配置类的字节码
@ComponentScan注解
作用:
用于指定spring在初始化容器时要扫描的包。作用和在spring的xml配置文件中的: <context:component-scan base-package="com.boke"/>是一样的。
属性:
basePackages:用于指定要扫描的包。和该注解中的value属性作用一样。
@Bean注解
@Bean:用于把当前方法的返回值作为bean对象存入spring的ioc容器中,他的name属性用于指定bean的id。当不写时,默认值是当前方法的名称
@Import注解
@Import用于导入其他的配置类
@PropertySource注解
作用:
@PropertySource用于加载.properties文件中的配置。例如我们配置数据源时,可以把连接数据库的信息写到properties配置文件中,就可以使用此注解指定properties配置文件的位置。
属性:
value[]:用于指定properties文件位置。如果是在类路径下,需要写上classpath
创建jdbc.properties文件
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/spring_02
jdbc.username=
jdbc.password=
使用@PropertySource指定配置文件
类中读取配置文件
@Configuration
@ComponentScan("com.boke")
@PropertySource("classpath:db.properties")
public class BeanFactory {
@Value("${jdbc.driver}")
private String driver ;
@Value("${jdbc.url}")
private String url ;
@Value("${jdbc.username}")
private String username ;
@Value("${jdbc.password}")
private String password ;
@Bean(name="queryRunner")
public QueryRunner getQueryRunner(DataSource dataSource){
return new QueryRunner(dataSource);
}
@Bean(name="dataSource")
public DataSource getDataSource() throws PropertyVetoException {
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setDriverClass(driver);
dataSource.setJdbcUrl(url);
dataSource.setUser(username);
dataSource.setPassword(password);
return dataSource;
}
}
@Qualifier注解
作用:
用来在形参中为参数取别名
属性:
value:参数的别名
四 纯注解配置
使用Spring新注解,替换掉原来的
applicationContext.xml
配置文件
创建配置文件db.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/spring_02
jdbc.username=root
jdbc.password=zl
创建配置类SpringConfig
@Configuration
@ComponentScan("com.boke")
@PropertySource("classpath:db.properties")
public class SpringConfig {
@Value("${jdbc.driver}")
private String driver ;
@Value("${jdbc.url}")
private String url ;
@Value("${jdbc.username}")
private String username ;
@Value("${jdbc.password}")
private String password ;
@Bean(name="queryRunner")
public QueryRunner getQueryRunner(@Qualifier("ds") DataSource dataSource){
return new QueryRunner(dataSource);
}
@Bean(name="ds")
public DataSource getDataSource() throws PropertyVetoException {
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setDriverClass(driver);
dataSource.setJdbcUrl(url);
dataSource.setUser(username);
dataSource.setPassword(password);
return dataSource;
}
}
修改测试类获取Spring容器操作
五 Spring整合Junit
1.导入Spring与Junit整合的依赖包
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.0.2.RELEASE</version>
</dependency>
2.在单元测试类上添加注解
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = SpringConfig.class)
public class UserServiceTest {
private UserService userService ;
@Test
public void findAll() {
List<User> users = userService.findAll();
System.out.println(users);
}
}
注意:
1. 如果使用注解配置, @ContextConfiguration 应该指定配置类的字节码
@ContextConfiguration(classes = SpringConfig.class)
2. 如果使用配置文件,@ContextConfiguration`应该指定配置文件的位置
@ContextConfiguration(locations = "classpath:beans.xml")
注解配置, @ContextConfiguration 应该指定配置类的字节码
@ContextConfiguration(classes = SpringConfig.class)
- 如果使用配置文件,@ContextConfiguration`应该指定配置文件的位置
@ContextConfiguration(locations = “classpath:beans.xml”)