Fork me on GitHub

Spring Bean装配之基于Java的容器注解

@Bean

用于配置和初始化一个有SpringIOC容器管理的新对象的方法,类似于XML配置文件的,通常和@Configuration配合使用

1
2
3
4
5
6
7
8
@Configuration
public class StoreConfig {

@Bean(name = "store",initMethod = "init",destroyMethod="destroy")
public BeanStore beanStore(){
return new BeanStore();
}
}

相当于以下XML配置

1
2
3
4
<beans>

<bean id="store" class="com.pinnuli.spring.ioc.beanannotation.BeanStore" init-method="init" destroy-method="destroy"></bean>
</beans>

如果@Bean没有指定名称,则默认为方法名,这里即是beanStore。

如果需要指定范围,即XML配置时的属性scope,那么可以用@Scope注解,且可以配置@Scope注解的proxyMode属性来配置代理方式,即XML配置时的scope-proxy属性

1
@Scope(value="prototype", proxyMode = ScopedProxyMode.TARGET_CLASS)

@ImportResource,@Value

通过@ImportResource加载资源文件,@Value获取属性值,比如有文件config.properties内容如下:

1
2
3
jdbc.username=root
password=root
url=127.0.0.1

则可以通过将此内容配置到XML文件,如config.xml

1
2
3
4
5
6
7
8
9
10
11
12
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd" >

<context:property-placeholder location="classpath:/config.properties"/>

</beans>

然后在定义bean时,通过@ImportResource加载文件,通过@Value获取属性的值

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@Configuration
@ImportResource("classpath:config.xml")
public class StoreConfig {

@Value("${url}")
private String url;

@Value("${jdbc.username}")
private String username;

@Value("${password}")
private String password;

@Bean
public MyDriverManager myDriverManager() {
return new MyDriverManager(url, username, password);
}
}

注意:这里的用户名字段如果直接为username,那么得到的将是当前系统的用户名,而不是文件中的属性值,所以一般此类属性名称加前缀,如jdbc.username,jdbc.password


基于泛型的自动装配

比如现有如下接口:

1
2
public interface Store<T> {
}

IntegerStoreStringStore是他的两个实现类:

1
2
public class IntegerStore implements Store<Integer> {
}

1
2
public class StringStore implements Store<String> {
}

那么在定义bean时可以按照如下方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@Autowired
private Store<String> s1;

@Autowired
private Store<Integer> s2;

@Bean
public StringStore stringStore() {
return new StringStore();
}

@Bean
public IntegerStore integerStore() {
return new IntegerStore();
}

那么s1将会自动装配到StringStores2将会是IntegerStore


JSR支持

JSR250的支持

1.@Resource
注解变量或方法,且有一个name属性值,默认Spring解释改值为被注入bean的名称,若没有指定name,那么名称从方法名或者属性名得出

1
2
3
4
5
6
7
8
9
10
11
@Service
public class JsrServie {

@Resource
private JsrDAO jsrDAO;

@Resource
public void setJsrDAO(@Named("jsrDAO") JsrDAO jsrDAO) {
this.jsrDAO = jsrDAO;
}
}

2.@PostConstruct和@PreDestroy
@PostConstruct,初始化,相当于init-Method属性
@PreDestroy,销毁,相当于destroy-Method属性

1
2
3
4
5
6
7
@PostConstruct
public void init() {
}

@PreDestroy
public void destroy() {
}

JSR330的支持

需要依赖javax.injet

1.@Inject
@Autowired等效,可以使用于类,属性,方法,构造器
2.@Named
使用特定名称进行依赖注入,与@Component等效

1
2
3
4
5
6
7
8
9
10
11
@Named
public class JsrServie {

@Inject
private JsrDAO jsrDAO;

@Inject
public void setJsrDAO(@Named("jsrDAO") JsrDAO jsrDAO) {
this.jsrDAO = jsrDAO;
}
}

参阅:
慕课网:Spring入门篇

-------------本文结束感谢您的阅读-------------

本文标题:Spring Bean装配之基于Java的容器注解

文章作者:pinnuli

发布时间:2018年07月29日 - 17:07

最后更新:2019年02月28日 - 10:02

原始链接:https://pinnuli.github.io/2018/07/29/Spring-Bean装配之基于Java的容器注解/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。