您的位置:首页 > 编程语言 > Java开发

Spring bean的配置

2015-11-25 10:43 357 查看
Bean的容器 Factory和Context,Context多了运行时上下文,提供读取资源文件,监听等等能力

Bean的生命周期:

实例化->填充属性->BeanNameAware的setBeanName方法, 调用BeanFactoryAware的setBeanFactory()方法,调用ApplicationContextAware的setApplicationContext()方法——》调用BeanPostProcessore的预初始化方法,调用InitializingBean的afterPropertiesSet()方法,调用定制的初始化方法用init-method声明的,调用BeanPostProcessors的后初始化方法。

容器关闭->调用DisposableBeande destroy()方法,调用定制的销毁方法-用destory-method声明的

全注解配置样例

@Configuration
public class AppConfig {
private @Value("#{jdbcProperties.url}") String jdbcUrl;
private @Value("#{jdbcProperties.username}") String username;
private @Value("#{jdbcProperties.password}") String password;

@Bean
public FooService fooService() {
return new FooServiceImpl(fooRepository());
}

@Bean
public FooRepository fooRepository() {
return new HibernateFooRepository(sessionFactory());
}

@Bean
public SessionFactory sessionFactory() {
// wire up a session factory
AnnotationSessionFactoryBean asFactoryBean =
new AnnotationSessionFactoryBean();
asFactoryBean.setDataSource(dataSource());
// additional config
return asFactoryBean.getObject();
}

@Bean
public DataSource dataSource() {
return new DriverManagerDataSource(jdbcUrl, username, password);
}
}


Spring IOC

org.springframework.beans和.context下完成的,beans的BeanFactory提供了IOC容器, context提供了资源管理,事件发布等

基本:

setter注入

<bean><property name="" value|ref=""></bean>


构造器注入

<bean><constructor-arg value|ref=""></bean>


内部bean:

<property name=""><bean class=""/></>


还可以用bean p:propertyName=”“这样的方式注入

装配集合,properties文件样式的键值对

空值
<null/>


自动装配 autowire=”byName”,命中多个会报错。还有其他,掠过

bean scope=

默认singleton, prototype每次调用一个新的,request,session,这两个作用于仅仅在Spring MVC中才有用范围 scope= sngleton默认值,容器一个, Prototype使用一次创建一个

利用工厂方法创建bean

factory-method=”methodName” methodName是一个静态方法返回该类的实例,特别适合用Spring管理单例

这样的感觉不太有用。 因为返回的是直接new的值, 不带有Spring的环境。 感觉可以使用SpringHolder来实现参数选择不同实现的那种工厂。没有想到更好的办法。

初始化和析构

bean init-method=”methodName”

配置的办法init-method和destroy-method. 编程的办法实现这两个接口:InitializingBean , DisposableBean atfter和destory

不同在于编程式的不需要额外的配置,Spring容器会自动处理。配置式的可以跟Spring不耦合。

都是在实例创建之后调用的

注解装配:

<context:annotation-config>


@Autowired 可以用在set方法,构造器,通常是用在属性上,然后省略set和get,其为byType装配,但是如果没有或者有多个都会报错:

没有@Autowired(request=false)会填空值

多个加上@Qualifier(“id”)来缩小范围

@Resource基于byName的,是JSR的规范,更小的依赖于Spring

@Inject JSR330,专门制定的用于依赖的注解,可以完全去掉Autowired

自动扫描bean,上面的实现了去除

高级bean装配

继承 被继承的abstract=”true”(表示spring不负责实例化只是作为模板),子类parent=”parentId”

方法注入
<replace-method name="methodName" replacer="beanId"><bean id="">
这个bean需要实现了spring的MethodReplacer类

自定义属性编辑器 PropertyEidtor和PropertyEidtorSupport类
<bean class="CustomEditorConfigurer"><property name="customEditors"><map><entry key="要解析的类的名称"><bean 使用的解析类的名称>


后处理bean BeanPostProcessor, postProcessBeforeInitialization.在调用bean的init方法之前实例化之后,postAfter,在调用init方法之后。ApplicationContextAwareProcessor

BeanFactoryPostProcessor在spring加载且任何bean被实例化之前CustomerEditorConfigurer,PropertyPlaceholderConfigurer

用属性文件需要AppliationContext, PropertyPlaceholderConfigurer指定属性文件的位置,其他配置用EL表达式使用。

国际化

国际化文件

在bean里装配ResourceBundleMessageSource(名称必须为messageSource)来使用java自己的ResourceBundle来提取消息,会被自动注入到context中用context.getMessage来获取信息,在JSP中可以用
<spring:message code="">
来获取信息

事件解耦

发布事件:context.publishEvent(new 实现ApplicationEvent)

监听事件:实现ApplicationListener并且声明为bean。当事件发布的时候会调用它的onApplicationEvent方法。有点想servlet的filter,比如调用publishEvent的这个时间点就会一次调用所有已经声明的Listener,需要注意的是这个是同步的,因此要注意效率

跟容器关联

BeanNameAwae, ApplicationContextAware。实现之后spring会自动注入。或者使用ContextHolder.

脚本化

<property name="" ref="">
这个部分跟正常的完全一样,然后ref部分我们使用一个脚本语言:
<lang:groovy id="ref" script-source="classpath:com/....groovy"/>
默认是不刷新的,可以定义刷新时间和使用内部代码的方式。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: