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

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

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

    小方的Java博客

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      27 隨筆 :: 17 文章 :: 115 評論 :: 0 Trackbacks
    我在做公司某個框架時有這么一個需求。每次調用dwr的方法前要檢查用戶是否已經登錄,否則就不能執行并且退到首頁。

    當然了,做攔截器有很多方式,但經過研究發現DWR自帶很多插件,其中就有一個調用處理的插件。具體做法如下。

    在web.xml里的DWR配置中加入一個參數:
    <init-param>
                
    <param-name>
                    org.directwebremoting.extend.Remoter
                
    </param-name>
                
    <param-value>com.xxx.base.framework.web.MyDWRRemoter</param-value>
            
    </init-param>

    然后自己創建這個實現類。
    public class MyDWRRemoter extends DefaultRemoter
    {

        
    public Replies execute( Calls calls )
        
    {
            HttpSession session 
    = WebContextFactory.get().getSession();
            ISessionContainer sc 
    = ( ISessionContainer ) session.getAttribute( ISessionContainer.SESSION_CONTAINER_KEY );

            
    //session檢查
            if ( sc == null || sc.getUserInfo() == null )
            
    {
                logOut();
                
    return super.execute( new Calls() );
            }

            
    else
            
    {
                IUserInfo userInfo 
    = sc.getUserInfo();
                
    if(!SecurityFactory.getInstance().isOnline( userInfo.getUserID(), session.getId() ))
                
    {
                    logOut();
                    
    return super.execute( new Calls() );
                }

            }

            
    return super.execute( calls );
        }


        
    private void logOut()
        
    {
            WebContext wct 
    = WebContextFactory.get();
            Util utilThis 
    = new Util(wct.getScriptSession());
            utilThis.addScript( 
    new ScriptBuffer("logOut()"));
        }

    }

    其中,檢查用戶是否登錄,如果沒有登錄就返回一個空的super.execute( new Calls());, 不能返回null否則會報錯。
    檢查通過就調用super.execute( calls );  其實calls里還能獲得很多信息。

    最后大家注意logOut方法,這里用到了DWR2.0新功能:DWR反向調用,就是DWR調用javascript,具體用法大家網上可以查到,需要配置的,我這里就不多說了。補充一下,addScript調用的是html里的function logOut().

    這樣的話,如果用戶session超時,或被管理員踢掉,一旦他做任何dwr操作就會被強迫登出到首頁了。
    posted on 2008-12-05 20:42 方佳瑋 閱讀(2902) 評論(3)  編輯  收藏 所屬分類: AJAX

    評論

    # re: [原創]DWR2.0的調用前攔截 2009-08-06 09:45 bln13fb
    ISessionContainer
    SecurityFactory
    如何導入  回復  更多評論
      

    # re: [原創]DWR2.0的調用前攔截 2010-01-21 10:15 方佳瑋
    @bln13fb

    這是我們公司自己的類,這里只是個范例,你自己有自己的類  回復  更多評論
      

    # re: [原創]DWR2.0的調用前攔截 2011-04-19 15:06 小簡
    在你這個應用里面怎么可以獲得請求的URL呀,我想判斷一下用戶是否對某一個資源是否有訪問權限的時候怎么樣才能知道他是訪問的那個資源呢  回復  更多評論
      

    主站蜘蛛池模板: 在线观看人成视频免费| 最近免费中文字幕高清大全| 成人免费无码大片a毛片| 久久亚洲精品成人AV| 一级毛片免费观看不卡视频| 亚洲AV无码国产精品色午友在线| 久久精品免费一区二区三区| 亚洲av午夜成人片精品网站| 性xxxxx大片免费视频| 久久精品国产精品亚洲蜜月| 久久成人免费大片| 亚洲精品中文字幕乱码影院 | 又硬又粗又长又爽免费看 | 最近中文字幕无免费| 亚洲综合色一区二区三区小说| 亚洲人成免费电影| 亚洲中文字幕久久精品无码VA| 国产精品成人无码免费| 一区在线免费观看| 亚洲国产精品不卡在线电影| 亚洲欧洲免费无码| 日本亚洲高清乱码中文在线观看| 亚洲精品综合久久| 日韩免费高清大片在线| 日本亚洲免费无线码| 亚洲国产专区一区| 日韩在线不卡免费视频一区| 91在线亚洲综合在线| 精品国产亚洲一区二区在线观看| 99在线观看精品免费99| 亚洲AⅤ男人的天堂在线观看 | 亚洲不卡无码av中文字幕| 中文字幕乱码免费看电影| 亚洲成a人片在线观看播放| 日本免费网站在线观看| a视频免费在线观看| 亚洲色大网站WWW永久网站| 久久亚洲国产精品五月天婷| 67194熟妇在线永久免费观看| 色多多www视频在线观看免费| 亚洲视频在线观看网址|