解析文本信息:
有時,你不希望硬編碼顯示給用戶信息。也許是因為這個信息經常發生改變,或者是你的應用系統提供國際化功能,你要用用戶的本地語言顯示文本。
java對文本國際化的支持使你能夠定義一個或多個屬性文件保存應用系統中需要顯示的文本。Spring的ApplicationContext通過MessageSource接口為容器提供參數化信息支持,Spring提供了一個現成的MessageSource實現。ResourceBundleMessageSource只是調用java自己的java.util.ResourceBundle來解析信息。
例如:
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
<property name="basename">
<value>trainingtext</value>
</property>
</bean>
這個Bean的名字必須是messageSource,因為ApplicationContext在裝配應用系統Bean的時候查找這個名字的Bean,你不需要將messageSource注入到應用系統中的Bean中,而是使用ApplicationContext自己的getMessage()方法。
Locale locale = ...;
第一個參數表示文本文件中的ID
第二個參數表示傳遞到資源文件中的數組,顯示最終文件
第三個參數表示采用哪種方式顯示
String text = context.getMessage("computer",new Object[0],locale);
監聽事件與發布事件:
如果你想對一個類的方法進行監聽,首先要定義事件,然后在這個方法中通過ApplicationContext發布它,最后在ApplicationContext.xml中定義這個監聽器。這樣,每當方法執行的時候,監聽器就會監聽到對應的事件的觸發。
事件分為ApplicationContext發布的事件和自定義的事件。這些事件都是抽象類org.springframework.context.ApplicationEvent的子類。
在應用系統生命周期中,ApplicationContext會發布很多事件,告訴感興趣的監聽器發生了什么事情。。系統事件有如下幾個:
1、ContextClosedEvent:在應用上下文關閉的時候發布的事件;
2、contextRefreshedEvent:在應用上下文初始化或刷新的時候發布的事件;
3、RequestHandledEvent:在web應用上下文中,當一個請求被處理后發布的事件。
首先要編寫為哪個類的哪個方法添加事件:
public class Animal implements ApplicationContextAware {
private ApplicationContext ac;
private String name;
private int age;
public String speak(){
ac.publishEvent(new AnimalSpeakEvent(this,this.name));
return " 我的名字是;"+this.name+",我的年齡是:"+this.age;
}
public void setApplicationContext(ApplicationContext arg0) throws BeansException {
this.ac = arg0;
}
//Getet和Seter省略
}
自定義事件入下:
import org.springframework.context.ApplicationEvent;
public class AnimalSpeakEvent extends ApplicationEvent {
private static final long serialVersionUID = 1L;
private String animalName;
public AnimalSpeakEvent(Object source) {
super(source);
}
public AnimalSpeakEvent(Object source,String animalName) {
super(source);
this.animalName = animalName;
}
public String getAnimalName() {
return animalName;
}
}
然后是實現監聽器,監聽器必須實現org.springframework.context.ApplicationListener接口。這個接口要求你的Bean實現onApplicationEvent()方法:
public class RefreshListener implements ApplicationListener{
public void onApplicationEvent(ApplicationEvent event){
}
}
import org.springframework.context.ApplicationEvent;
import org.springframework.context.ApplicationListener;
public class AnimalEventListener implements ApplicationListener {
public void onApplicationEvent(ApplicationEvent event) {
if (event instanceof AnimalSpeakEvent) {
AnimalSpeakEvent a = (AnimalSpeakEvent) event;
System.out.println("事件監聽器" + this.getClass().getSimpleName()+":有一個動物在講話!它的名字是:"+ a.getAnimalName());
}
}
}
最后就是在映射文件中定義這個監聽器:
<?xml version="1.0" encoding="UTF-8"?>
<beans …………>
<bean id="Listener" class="ioc.test.AnimalEventListener" />
<bean id="Animal" class="ioc.test.Animal">
<property name="name" value="老虎" />
<property name="age" value="5" />
</bean>
</beans>
最后是測試類:
import org.springframework.context.support.AbstractApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext;
public class TestMain {
public static void main(String[] args) {
AbstractApplicationContext ac = new ClassPathXmlApplicationContext(
"applicationContext.xml");
//從容器獲取動物實例
Animal animal = (Animal)ac.getBean("Animal");
//讓動物講話
System.out.println(animal.speak());
}
}
感知其他Bean:
在極大程度上,運行在Spring容器中的Bean就像生活在The Matrix里的人類。對于這些Bean來說,他們不知道自己的注冊名,甚至不知道自己運行在容器中。通常這是好事,因為如果一個Bean知道容器的存在的話,他就和Spring耦合在一起了,在容器以外無法存在。
但有時候Bean需要知道更多信息。有時他們需要知道他們是誰,他們在哪里運行。有時他們需要服用那顆紅色藥丸。
在Spring Bean環境中,紅色藥丸就是BeanNameAware、BeanFactoryAware和ApplicationContextAware接口。通過實現這3個接口,Bean分別可以知道自己的名字,他們所處的BeanFactory以及他們所處的ApplicationContext.
注意,通過實現這些接口,一個Bean就和Spring耦合在一起。
感知系統容器對于Bean來說是福是禍。一方面,應用上下文的獲得給Bean提供了很多權利。另一方面,知道容器會把Bean和Spring耦合起來,這是要盡量避免的事情。
posted on 2009-11-03 20:52
王永慶 閱讀(168)
評論(0) 編輯 收藏 所屬分類:
SPRING