<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 66,  comments - 11,  trackbacks - 0
    解析文本信息:
    有時,你不希望硬編碼顯示給用戶信息。也許是因為這個信息經常發生改變,或者是你的應用系統提供國際化功能,你要用用戶的本地語言顯示文本。
    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
    <2009年11月>
    25262728293031
    1234567
    891011121314
    15161718192021
    22232425262728
    293012345

    常用鏈接

    留言簿(1)

    隨筆分類

    隨筆檔案

    關注blogs

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 在线电影你懂的亚洲| 亚洲国产精品成人| 亚洲视频精品在线| 亚洲A∨精品一区二区三区| 又粗又大又硬又爽的免费视频| 亚洲午夜国产精品无码老牛影视| 日本免费精品一区二区三区 | 亚洲乱码一区二区三区在线观看| 一级特级aaaa毛片免费观看| 日本人的色道免费网站| 亚洲第一页在线视频| 18级成人毛片免费观看| 亚洲喷奶水中文字幕电影| 在线观看av永久免费| 亚洲国产精品久久久久| 1区2区3区产品乱码免费| 亚洲人成高清在线播放| 免费看香港一级毛片| 美女视频黄a视频全免费网站色| 亚洲综合亚洲综合网成人| 精品在线免费观看| 亚洲午夜电影在线观看| 国产色婷婷精品免费视频| 一级做a爰片久久毛片免费陪 | 91视频免费网站| 亚洲国产精品无码久久久| 在线天堂免费观看.WWW| 美女裸免费观看网站| 亚洲精品无码不卡在线播放HE| 久久www免费人成看片| 亚洲AV无码国产剧情| 亚洲人成人一区二区三区| 久久国内免费视频| 日韩免费高清一级毛片| 亚洲av中文无码乱人伦在线r▽ | 在线观看亚洲AV每日更新无码| 亚洲精品偷拍视频免费观看| 免费国产污网站在线观看15| 亚洲欧美第一成人网站7777| 亚洲成a人片77777kkkk| 青青操免费在线视频|