關鍵字: spring
一、ApplicationContextAware接口
當一個類需要獲取ApplicationContext實例時,可以讓該類實現ApplicationContextAware接口。代碼展示如下:
- public class Animal implements ApplicationContextAware, BeanNameAware{
- private String beanName;
- private ApplicationContext applicationContext;
- public void setBeanName(String name) {
- this.beanName = name;
- }
- /**
- * @param applicationContext 該參數將由Spring容器自動賦值
- */
- public void setApplicationContext(ApplicationContext applicationContext)throws BeansException {
- this.applicationContext = applicationContext;
- }
- public void run(){
- System.out.println(beanName);
- //發佈自定義事件
- AnimalEvent event = new AnimalEvent(this, "老虎");
- applicationContext.publishEvent(event);
- }
- }
public class Animal implements ApplicationContextAware, BeanNameAware{
private String beanName;
private ApplicationContext applicationContext;
public void setBeanName(String name) {
this.beanName = name;
}
/**
* @param applicationContext 該參數將由Spring容器自動賦值
*/
public void setApplicationContext(ApplicationContext applicationContext)throws BeansException {
this.applicationContext = applicationContext;
}
public void run(){
System.out.println(beanName);
//發佈自定義事件
AnimalEvent event = new AnimalEvent(this, "老虎");
applicationContext.publishEvent(event);
}
}
二、ApplicationEvent抽象類
當需要創建自定義事件時,可以新建一個繼承自ApplicationEvent抽象類的類。代碼展示如下:
- /**
- * 自定義事件
- */
- public class AnimalEvent extends ApplicationEvent {
- private String name;
- public String getName() {
- return name;
- }
- /**
- * @param source 事件源對象
- */
- public AnimalEvent(Object source){
- super(source);
- }
- public AnimalEvent(Object source, String name){
- super(source);
- this.name = name;
- }
- }
/**
* 自定義事件
*/
public class AnimalEvent extends ApplicationEvent {
private String name;
public String getName() {
return name;
}
/**
* @param source 事件源對象
*/
public AnimalEvent(Object source){
super(source);
}
public AnimalEvent(Object source, String name){
super(source);
this.name = name;
}
}
三、ApplicationListener接口
當需要監聽自定義事件時,可以新建一個實現ApplicationListener接口的類,並將該類配置到Spring容器中。代碼展示如下:
- /**
- * 自定義事件監聽器
- */
- public class CustomEventListener implements ApplicationListener {
- public void onApplicationEvent(ApplicationEvent event) {
- if(event instanceof AnimalEvent){
- AnimalEvent animalEvent = (AnimalEvent)event;
- System.out.println("觸發自定義事件:Animal name is " + animalEvent.getName());
- }
- }
- }
/**
* 自定義事件監聽器
*/
public class CustomEventListener implements ApplicationListener {
public void onApplicationEvent(ApplicationEvent event) {
if(event instanceof AnimalEvent){
AnimalEvent animalEvent = (AnimalEvent)event;
System.out.println("觸發自定義事件:Animal name is " + animalEvent.getName());
}
}
}
- <!-- 自定義事件監聽器:Spring容器自動註冊它 -->
- <bean id="customEventListener" class="com.cjm.spring.CustomEventListener"/>
<!-- 自定義事件監聽器:Spring容器自動註冊它 -->
<bean id="customEventListener" class="com.cjm.spring.CustomEventListener"/>
要發佈自定義事件,需要調用ApplicationContext的publishEvent方法,具體用法請看Animal類的源碼。
四、BeanNameAware接口
當bean需要獲取自身在容器中的id/name時,可以實現BeanNameAware接口。
五、InitializingBean接口
當需要在bean的全部屬性設置成功後做些特殊的處理,可以讓該bean實現InitializingBean接口。
效果等同於bean的init-method屬性的使用。
先執行InitializingBean接口中定義的方法,然後執行init-method屬性指定的方法。
六、DisposableBean接口
當需要在bean銷燬之前做些特殊的處理,可以讓該bean實現DisposableBean接口。
效果等同於bean的destroy-method屬性的使用。
先執行DisposableBean接口中定義的方法,然後執行destroy-method屬性指定的方法。
七、BeanPostProcessor接口
當需要對受管bean進行預處理時,可以新建一個實現BeanPostProcessor接口的類,並將該類配置到Spring容器中。
實現BeanPostProcessor接口時,需要實現以下兩個方法:
postProcessBeforeInitialization 在受管bean的初始化動作之前調用
postProcessAfterInitialization 在受管bean的初始化動作之後調用
,容器中的每個Bean在創建時都會恰當地調用它們。代碼展示如下:
- public class CustomBeanPostProcessor implements BeanPostProcessor {
- /**
- * 初始化之前的回調方法
- */
- public Object postProcessBeforeInitialization(Object bean, String beanName)throws BeansException {
- System.out.println("postProcessBeforeInitialization: " + beanName);
- return bean;
- }
- /**
- * 初始化之後的回調方法
- */
- public Object postProcessAfterInitialization(Object bean, String beanName)throws BeansException {
- System.out.println("postProcessAfterInitialization: " + beanName);
- return bean;
- }
- }
public class CustomBeanPostProcessor implements BeanPostProcessor {
/**
* 初始化之前的回調方法
*/
public Object postProcessBeforeInitialization(Object bean, String beanName)throws BeansException {
System.out.println("postProcessBeforeInitialization: " + beanName);
return bean;
}
/**
* 初始化之後的回調方法
*/
public Object postProcessAfterInitialization(Object bean, String beanName)throws BeansException {
System.out.println("postProcessAfterInitialization: " + beanName);
return bean;
}
}
- <!-- 自定義受管Bean的預處理器:Spring容器自動註冊它 -->
- <bean id="customBeanPostProcessor" class="com.cjm.spring.CustomBeanPostProcessor"/>
八、BeanFactoryPostProcessor接口
當需要對Bean工廠進行預處理時,可以新建一個實現BeanFactoryPostProcessor接口的類,並將該類配置到Spring容器中。代碼展示如下:
- public class CustomBeanFactoryPostProcessor implements BeanFactoryPostProcessor {
- public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
- System.out.println(beanFactory.getClass().getSimpleName());
- }
- }
public class CustomBeanFactoryPostProcessor implements BeanFactoryPostProcessor {
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
System.out.println(beanFactory.getClass().getSimpleName());
}
}
- <!-- 自定義Bean工廠的預處理器:Spring容器自動註冊它 -->
- <bean id="customBeanFactoryPostProcessor" class="com.cjm.spring.CustomBeanFactoryPostProcessor"/>
Spring內置的實現類:
1、PropertyPlaceholderConfigurer類
用於讀取Java屬性文件中的屬性,然後插入到BeanFactory的定義中。
- <bean id="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
- <property name="locations">
- <list>
- <value>jdbc.properties</value>
- </list>
- </property>
- </bean>
- <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
- <property name="driverClassName"><value>${jdbc.driverClassName}</value></property>
- <property name="url"><value>${jdbc.url}</value></property>
- <property name="username"><value>${jdbc.username}</value></property>
- <property name="password"><value>${jdbc.password}</value></property>
- </bean>
Java屬性文件內容:
jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=qycd
jdbc.password=qycd
除了可以讀取Java屬性文件中的屬性外,還可以讀取系統屬性和系統環境變量的值。
讀取系統環境變量的值:${JAVA_HOME}
讀取系統屬性的值:${user.dir}
2、PropertyOverrideConfigurer類
用於讀取Java屬性文件中的屬性,並覆蓋XML配置文件中的定義,即PropertyOverrideConfigurer允許XML配置文件中有默認的配置信息。
Java屬性文件的格式:
beanName.property=value
beanName是屬性佔位符企圖覆蓋的bean名,property是企圖覆蓋的數姓名。
- <bean id="propertyOverrideConfigurer" class="org.springframework.beans.factory.config.PropertyOverrideConfigurer">
- <property name="locations">
- <list>
- <value>jdbc.properties</value>
- </list>
- </property>
- </bean>
- <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
- <property name="driverClassName" value="11"/>
- <property name="url" value="22"/>
- <property name="username" value="33"/>
- <property name="password" value="44"/>
- </bean>
Java屬性文件內容:
dataSource.driverClassName=oracle.jdbc.driver.OracleDriver
dataSource.url=jdbc:oracle:thin:@localhost:1521:orcl
dataSource.username=qycd
dataSource.password=qycd
九、ResourceBundleMessageSource類
提供國際化支持,bean的名字必須爲messageSource。
- <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
- <property name="basenames">
- <list>
- <value>jdbc</value>
- </list>
- </property>
- </bean>