<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        ajax請求Session失效問題

        來源:懂視網 責編:小采 時間:2020-11-27 22:52:06
        文檔

        ajax請求Session失效問題

        ajax請求Session失效問題:最近由于一個項目,模塊切換為ajax請求數據,當Session失效后,ajax請求后沒有返回值,只有響應的html: <html> <script type='text/javascript'>window.open('http://192.168.0.118:8080/welcomeActi
        推薦度:
        導讀ajax請求Session失效問題:最近由于一個項目,模塊切換為ajax請求數據,當Session失效后,ajax請求后沒有返回值,只有響應的html: <html> <script type='text/javascript'>window.open('http://192.168.0.118:8080/welcomeActi

        最近由于一個項目,模塊切換為ajax請求數據,當Session失效后,ajax請求后沒有返回值,只有響應的html:

        <html>
        <script type='text/javascript'>window.open('http://192.168.0.118:8080/welcomeAction/loginUI.do','_top');
        </script>
        </html>

        現在Ajax在Web項目中應用廣泛,幾乎可以說無處不在,這就帶來另外一個問題:當Ajax請求遇到Session超時,應該怎么辦?

        顯而易見,傳統的頁面跳轉在此已經不適用,因為Ajax請求是XMLHTTPRequest對象發起的而不是瀏覽器,在驗證失敗后的頁面跳轉無法反應到瀏覽器中,因為服務器返回(或輸出)的信息被JavaScript(XMLHTTPRequest對象)接到了。

        那么應該怎么處理這種情況呢?

        方法

        既然服務器返回的消息被XMLHTTPRequest對象接收,而XMLHTTPRequest對象又是在JavaScript的掌控之中,那么我們是否可以利用JavaScript來完成頁面跳轉呢?

        當然可以,而且很容易實現!但有一點,我們需要判斷一下HTTP請求是否為Ajax請求(因為AJAX請求和普通的請求需要分開處理),這又如何判斷呢?其實Ajax請求和普通的HTTP請求是不同的,這體現在HTTP請求的頭信息中,如下所示:

        上面兩張圖片是用火狐的Firebug截取的,前者是普通的HTTP請求頭信息;后者為Ajax請求的請求頭信息。注意第一圖片被紅框圈起來的部分,這就是Ajax請求與普通請求不同的地方,AJAX請求頭中帶有X-Requested-With信息,其值為XMLHttpRequest,這正是我們可以利用的地方。

        下面看一下代碼如何實現。

        Interceptor過濾器

           在使用Struts2時,我們一般使用Interceptor(攔截器)來攔截權限問題。

        攔截器部分代碼:

        public String intercept(ActionInvocation invocation) throws Exception {
         // TODO Auto-generated method stub
         ActionContext ac = invocation.getInvocationContext();
         HttpServletRequest request = (HttpServletRequest) ac.get(StrutsStatics.HTTP_REQUEST);
         String requestType = request.getHeader("X-Requested-With");
         System.out.println("+++++++++++++++++++++++reqestType:"+requestType);
         HttpServletResponse response = (HttpServletResponse) ac.get(StrutsStatics.HTTP_RESPONSE);
         // String basePath = request.getContextPath();
         String path = request.getContextPath(); 
         String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path; 
         //獲取session
         Map session = ac.getSession();
         //判斷session是否存在及session中的user信息是否存在,如果存在不用攔截
         if(session != null && session.get(Constants.FE_SESSION_BG_USER) != null && session.get(Constants.FE_SESSION_BG_AUTH) != null){
         System.out.println(invocation.getProxy().getActionName()+"++++++++++++++++++++++++");
         System.out.println("namespace:"+invocation.getProxy().getNamespace());
         //訪問路徑
         String visitURL = invocation.getProxy().getNamespace() + "/" + invocation.getProxy().getActionName() + Constants.FE_STRUTS_ACTION_EXTENSION;
         visitURL = visitURL.substring();
         Map<String , Object> authMap = (Map<String, Object>) session.get(Constants.FE_SESSION_BG_AUTH);
         Map<Integer, String> actionMap = (Map<Integer, String>) authMap.get(Constants.FE_BG_ACTIONMAP);
         if(actionMap != null && !actionMap.isEmpty() && visitURL != null){
         if (actionMap.containsValue(visitURL)) {
         System.out.println(visitURL+"-----------------------");
         return invocation.invoke();
         } else{
         String forbidden = basePath + Constants.FE_BG_FORBIDDEN;
         response.sendRedirect(forbidden);
         return null;
         }
         }
         return invocation.invoke();
         }else{
         if(StringUtils.isNotBlank(requestType) && requestType.equalsIgnoreCase("XMLHttpRequest")){
         response.setHeader("sessionstatus", "timeout"); 
         response.sendError(, "session timeout."); 
         return null;
         }else {
         
         String actionName = invocation.getProxy().getActionName();
         System.out.println(actionName);
         //如果攔截的actionName是loginUI或login,則不做處理,否則重定向到登錄頁面
         if (StringUtils.isNotBlank(actionName) && actionName.equals(Constants.FE_BG_LOGINUI)) {
         return invocation.invoke();
         }else if(StringUtils.isNotBlank(actionName) && actionName.equals(Constants.FE_BG_LOGIN)){
         return invocation.invoke();
         }else{
         String login = basePath + "/" + Constants.FE_BG_LOGIN_NAMESPACE + "/" + Constants.FE_BG_LOGINUI + Constants.FE_STRUTS_ACTION_EXTENSION;
         // System.out.println("+++++++++++++++++++++++++++basePath:"+basePath);
         // response.sendRedirect(login);
         PrintWriter out = response.getWriter();
         // out.println("<html>"); 
         // out.println("<script>"); 
         // out.println("window.open ('"+login+"','_top');"); 
         // out.println("</script>"); 
         // out.println("</html>");
         out.write("<html><script type='text/javascript'>window.open('"+login+"','_top');</script></html>");
         return null;
         }
         }
         }
         
         }

        由上面代碼可以看出,當Session驗證失敗(即Session超時)后,我們通過HttpServletRequest取得請求頭信息X-Requested-With的值,如果不為空且等于XMLHttpRequest,那么就說明此次請求是Ajax請求,我們作出的反應就是向響應中添加一條頭信息(自定義)并且使響應對象HttpServletResponse返回服務器錯誤信息(518狀態是自己隨便定義的);這些信息都會被JavaScript接收,那么下面的工作就要將由JavaScript代碼了。

        Javascript代碼

        $.ajaxSetup方法是來設置AJAX請求默認選項的,我們可以認為是全局的選項設置,因此可以將這段代碼提到外部JS文件中,在需要的頁面引用。

         /**
         * 設置未來(全局)的AJAX請求默認選項
         * 主要設置了AJAX請求遇到Session過期的情況
         */
         $.ajaxSetup({
         type: 'POST',
         complete: function(xhr,status) {
         var sessionStatus = xhr.getResponseHeader('sessionstatus');
         if(sessionStatus == 'timeout') {
         var top = getTopWinow();
         var yes = confirm('由于您長時間沒有操作, session已過期, 請重新登錄.');
         if (yes) {
         top.location.href = '/skynk/index.html'; 
         }
         }
         }
         });
         /**
         * 在頁面中任何嵌套層次的窗口中獲取頂層窗口
         * @return 當前頁面的頂層窗口對象
         */
         function getTopWinow(){
         var p = window;
         while(p != p.parent){
         p = p.parent;
         }
         return p;
         }

        以上內容是腳本之家小編跟大家分享的ajax請求Session失效問題,希望對大家有用。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        ajax請求Session失效問題

        ajax請求Session失效問題:最近由于一個項目,模塊切換為ajax請求數據,當Session失效后,ajax請求后沒有返回值,只有響應的html: <html> <script type='text/javascript'>window.open('http://192.168.0.118:8080/welcomeActi
        推薦度:
        標簽: 過期 請求 問題
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲人成网站日本片| 国产AV无码专区亚洲精品| 亚洲婷婷综合色高清在线| 日本黄色动图免费在线观看| 亚洲欭美日韩颜射在线二| 日本一区二区三区免费高清在线| 日本一区二区三区日本免费| 中文字幕亚洲综合久久综合| 四虎影院免费在线播放| 亚洲成a∧人片在线观看无码| 精品少妇人妻AV免费久久洗澡| 看亚洲a级一级毛片| 亚洲精品专区在线观看| 中文字幕无线码中文字幕免费| 亚洲精品无码久久一线| 一级毛片不卡片免费观看| 亚洲最新视频在线观看| 黄页免费的网站勿入免费直接进入| 亚洲一区二区三区乱码在线欧洲| 暖暖在线日本免费中文| 人妻18毛片a级毛片免费看| 亚洲色偷拍另类无码专区| 人妻丰满熟妇无码区免费| jlzzjlzz亚洲jzjzjz| 国产麻豆免费观看91| 国产在线国偷精品免费看| 666精品国产精品亚洲| 成人毛片18女人毛片免费视频未| 国产精品亚洲天堂| 国产亚洲精品一品区99热| 免费人成在线观看69式小视频| 亚洲GV天堂无码男同在线观看| 高清在线亚洲精品国产二区| 久久青草免费91线频观看不卡| 国产亚洲国产bv网站在线| 亚洲人成色77777在线观看大| 84pao国产成视频免费播放| 亚洲国产无线乱码在线观看| 亚洲日韩aⅴ在线视频| 女人被男人桶得好爽免费视频| 中文字幕不卡高清免费|