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

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

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

    Sealyu

    --- 博客已遷移至: http://www.sealyu.com/blog

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      618 隨筆 :: 87 文章 :: 225 評論 :: 0 Trackbacks
    前一段時間我寫過一篇共享我在項目中使用jsf的一些經驗,主要是概要的提出了一些jsf使用上的建議,這次我想在文章里主要是把seam在jsf中的使用經驗提一下,能讓更多的人了解seam的實際應用和優勢。
        1.seam配置時要注意的地方:
        (1)faces-config.xml里面要加入一個seam的階段監聽:
        
    <lifecycle>
    <phase-listener>org.jboss.seam.jsf.SeamPhaseListener</phase-listener>
    <!-- <phase-listener>com.future.egov.jsf.ext.event.DebugPhaseListener</phase-listener> -->
    </lifecycle>

         seam動起來的條件就是從這里發起的,seam通過這個監聽器對jsf的各個階段進行必要的增強以及植入自己的CONVERSATION生命周期,對于這個監聽器的具體細節工作,我還需要更多時間研究,仍在了解中!
          (2) 一定要在工程類路徑的根下放置一個seam.properties文件,你可以設置為空內容,主要是引導seam在初始化的時候加載這個路徑下所有標注為seam組件的對象(通過@Name注釋),http://www.ibm.com/developerworks/cn/java/j-seam1/  seam無縫集成jsf給我了提示!
          (3)web.xml下最小配置是加入seam監聽器
            
        <listener>
              
    <listener-class>org.jboss.seam.servlet.SeamListener</listener-class>
        
    </listener>
           在容器加載工程的時候,初始化seam框架。
          以上三處的配置,你就可以在任何容器中使用seam了!更多的配置大家可以找參考了解吧,我目前在項目中就使用了以上配置。其他配置主要是在seam對ajax,ejb3的支持上,不過seam很新,什么事都會發生!
       2.常用的注釋:(所有被seam定義的領域對象都可以認為是seam組件)
         (1)@Name(XXX),需要在你的領域類上定義,定義了seam組件的名稱,對于jsf來說就是backing-bean,也就是說你不用在faces-config中配置managedbean了!

          (2)@Scope(ScopeType.XXX),可以在你的領域類上定義,表示這個被定義的seam組件在什么上下文中,jsf中主要包括 page,event,session,application,conversation這些Scope。我在項目中主要使用 event,session,conversation。event就是把組件放入了request中,session同理,conversation是 seam獨創的聲命周期,conversation短聲命周期類似request,但是會保存一些jsf容易在請求中丟失的數據(jsf只是保存組件,不 保存組件渲染的數據,除非是EditableValueHolder組件,有時候需要通過myfaces的save組件和 updateActionListener組件來恢復這些數據),具體保存細節,需要看使用的情況,我有這樣一個經驗:當定義成event上下文,在頁面 的一次請求中,有些數據請求時還在,但是到渲染時就不見了,常見在dataTable組件,myfaces的commandNavigation組件,但 是換成conversation上下文,這些數據在渲染時又找回來了。但是對于跨度比較大層面,我還是推薦使用myfaces提供的保持機制,我一般使用 updateActionListener,而save組件在seam1.2.1的環境下會出錯。如果再有更大跨度,就可以使用conversation 上下文的長會話了。

           (3)@Begin(join=true),@End(beforeRedirect=true),當觸發了帶有@Begin標記的方 法,conversation的長會話就這樣開始了,主要是為了長時間使用已經加載到conversation域中的對象或者屬性(如果定義了 conversation但并沒有加載的可不算):join=true就是告訴你會話中有同名值時繼續賦值,還有一個注釋參數 ifOutcome=XXX,就是看你的方法返回的字符串是否和ifOutcome定義的字符串相匹配,如果匹配就開始長會話。當在長會話期間執行到某個 方法帶有@End標記那么這個長會話就會結束,這樣防止了內存泄漏問題,我認為這是一個權衡的結果,也許用戶真的會點擊那個帶有結束標記方法的按鈕。 beforeRedirect為真就會在結束時清掉conversation上下文所有的信息,如果 beforeRedirect=false,conversation只是變成短會話,在結束后的那次請求中還可以使用conversation中的數 據,一般會用在messages提示這個應用場景中使用,但是如果要返回數據列表有時就需要清空所有數據,防止數據列表還會重現長會話開始前的情況。

           (4)In(value=XXX,rquest=false,ScopeType=XXX),Out(value=XXX,rquest=false,ScopeType=XXX) seam把它定義為雙射。In是最常用的標注,你可以使用In導入一個jsf的EL變量來獲取jsf模型,例如我要獲取spring的業務bean,而且 業務bean已經定義成backing bean,利用spring與jsf集成的方法:
           
        <!-- Managed Beans for options.jsp -->
        
    <application>
            
    <variable-resolver>
                org.springframework.web.jsf.DelegatingVariableResolver
            
    </variable-resolver>
            
    <locale-config>
                
    <default-locale>gbk</default-locale>
            
    </locale-config>
            
    <message-bundle>resources/MessageBundle</message-bundle>
            
    <!--  <view-handler>com.icesoft.faces.facelets.D2DFaceletViewHandler
            </view-handler>        
    -->
        
    </application>

         在seam組件中這樣聲明:
    @In(value="#{userService}", request=false)
    private UserService userService;

     這個示例為seam組件注入了由spring管理的用戶服務對象,它的value是從jsf EL變量中獲取,request=false在告訴seam,如果當前的值沒有找到,那么設置為空,否者當出現沒有找到的情況,seam會拋出空異常。
    @Out屬性主要是把處理過的屬性值會由seam重新再付給上下文也就是Out中所定義的ScopeType上下文,我認為雖然是seam的一個特點,但 是在我的應用中不多,主要是注入而非雙射!如果它真的能在短期Conversation中有所作用來代替Myfaces的數據保持機制,我想會好些,我目 前只是在長Conversation有所應用。

    3 .@Factory,@DataModelSelection,@DataModel, 它們主要來代替數據列表的使用,主要是減少了代碼量,Factory是在請求值階段就對需要實例化的對象進行創建,DataModelSelection 定義的屬性,可以透明的抓取數據列表選擇的單行數據,DataModel屬性減少了不必要的get,set。然而我在實際的使用中由于很多不定的情況,大 部分的使用上又回到jsf標準的get方式。 這種開發方式我認為seam的目的是想屏蔽與頁面不必要的關系細節,讓開發只需要重視真正的業務,是一個標準的面向對象式結構,當jsf的體系結構的不斷 優化,類似這種開發方式我想會越來越有用。
    4. @RequestParameter是個很有用的注釋,它自動把當前屬性和頁面同名的request提交值綁定在一起,雖然這樣使用違背了jsf所追求的面向對象化,http透明化,但是實際開發中會后很多意想不到的情況,有時候在集成式頁面這樣的做法會很有用,當你的頁面中不僅僅有jsf標簽就清楚了!

    seam的其他方面問題我會抽空整理一下,seam目前也是在不斷更新當中,明年出臺的webBeans規范的前身就是seam,其實我更關注的是 seam在整個j2ee體系中的角色,它到底是想替代struts的application?還是想替代spring的manager?也許有更多的想 法!
    posted on 2009-03-02 21:46 seal 閱讀(265) 評論(0)  編輯  收藏 所屬分類: Seam
    主站蜘蛛池模板: 国产在线观看免费视频软件 | 日韩亚洲国产综合高清| 国产高清不卡免费视频| 免费三级毛片电影片| 4480yy私人影院亚洲| 亚洲国产成人AV网站| 久久久久久国产精品免费免费男同 | 手机在线免费视频| 亚洲伊人久久大香线蕉AV| 最近的2019免费中文字幕| 亚洲性猛交XXXX| 免费国产在线视频| 亚洲精品无码久久久久久久| 无码国产精品一区二区免费式直播 | 亚洲丁香婷婷综合久久| 日韩中文字幕免费| 无遮挡免费一区二区三区| 亚洲午夜成人精品电影在线观看| 亚洲三级高清免费| 性做久久久久免费看| 亚洲精品视频免费 | 手机看黄av免费网址| 亚洲精品成a人在线观看夫| 一本久到久久亚洲综合| 97久久国产亚洲精品超碰热| 人妻丰满熟妇无码区免费| 亚洲性69影院在线观看| 日韩在线免费看网站| 亚洲免费在线视频观看| 日韩在线视频免费看| 亚洲国产一区二区三区在线观看| 美丽的姑娘免费观看在线播放 | 波多野结衣中文字幕免费视频| 亚洲精品中文字幕乱码三区| 无码人妻久久一区二区三区免费 | 免费可以看黄的视频s色| 四虎影视久久久免费观看| 亚洲AV无码久久精品狠狠爱浪潮 | 成人午夜视频免费| 91精品成人免费国产| 久久精品国产亚洲AV蜜臀色欲|