webix+springmvc session超時跳轉登錄頁面

来源:http://www.cnblogs.com/lijinxin/archive/2016/10/30/6012966.html
-Advertisement-
Play Games

2016-10-30 13:11:56 引言 最近做項目,發現ajax請求不能在伺服器中直接重定向到登錄頁面。查了些資料發現jquery的ajax請求有人給出了方法。但是webix的ajax請求和jquery的有些區別。這裡模仿jquery的處理方式實現webix的ajax請求session超時跳轉 ...


2016-10-30 13:11:56

引言

最近做項目,發現ajax請求不能在伺服器中直接重定向到登錄頁面。查了些資料發現jquery的ajax請求有人給出了方法。但是webix的ajax請求和jquery的有些區別。這裡模仿jquery的處理方式實現webix的ajax請求session超時跳轉。

 

具體的做法:

1、查看webix.js源碼發現webix.ajax只有請求前的監聽函數 "onBeforeAjax", 要做到獲取返回狀態跳轉登錄頁面必須要有個返回的監聽函數,但是源碼沒有。所以我修改了下源碼,加了個返回的監聽函數"onAfterAjax"。

紅色標記部分是我加的代碼,當檢測到ajax完成時,自動執行"onAfterAjax"。(代碼的位置可以搜索webix.js ,條件"onBeforeAjax",然後在對應的位置加入紅色代碼就行

  if (webix.callEvent("onBeforeAjax", [s, t, e, a, o, null, r])) {
            var h = !1;
            if ("GET" !== s) {
                var l = !1;
                for (var c in o)"content-type" == c.toString().toLowerCase() && (l = !0, "application/json" == o[c] && (h = !0));
                l || (o["Content-Type"] = "application/x-www-form-urlencoded")
            }
            if ("object" == typeof e)if (h)e = this.stringify(e); else {
                var u = [];
                for (var d in e) {
                    var f = e[d];
                    (null === f || f === webix.undefined) && (f = ""), "object" == typeof f && (f = this.stringify(f)), u.push(d + "=" + encodeURIComponent(f))
                }
                e = u.join("&")
            }
            e && "GET" === s && (t = t + (-1 != t.indexOf("?") ? "&" : "?") + e,
                e = null), a.open(s, t, !this.H);
            var b = this.Tw;
            b && (a.responseType = b);
            for (var c in o)a.setRequestHeader(c, o[c]);
            var x = this;
            return this.master = this.master || n, a.onreadystatechange = function () {
                if (!a.readyState || 4 == a.readyState) {
                    if (webix.callEvent("onAfterAjax", [a]) === !1) {
                        return false;
                    };
                    if (webix.ajax.count++, i && x && !a.aborted) {
                        if (-1 != webix.ly.find(a))return webix.ly.remove(a);
                        var t, e, s = x.master || x, r = a.status >= 400 || 0 === a.status;
                        "blob" == a.responseType || "arraybuffer" == a.responseType ? (t = "", e = a.response) : (t = a.responseText || "", e = x.J(a)), webix.ajax.$callback(s, i, t, e, a, r)
                    }
                    x && (x.master = null), i = x = n = null
                }
            }, this.qh && (a.timeout = this.qh), this.H ? a.send(e || null) : setTimeout(function () {
                a.aborted || (-1 != webix.ly.find(a) ? webix.ly.remove(a) : a.send(e || null));
            }, 1), this.master && this.master.Ve && this.master.Ve.push(a), this.H ? a : r
        }

 

2、webix.ajx請求沒有明顯的標誌,jquery.ajax的標識是x-requested-with ,所以我模擬給了個標識requestFlag="webix"(可以自己設置個喜歡的),用"onBeforeAjax"設置

webix.attachEvent("onBeforeAjax",function(s, t, e, a, o){o["requestFlag"]="webix"})

 

 3、監聽返回狀態

webix.attachEvent("onAfterAjax",function(xhr){if(xhr.getResponseHeader("sessionstatus")=='timeout'){window.location.href='/webix/login.html'}});

 

 4、後臺代碼

4.1  攔截器代碼

package com.ljx.filter;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

public class UserInterceptor implements HandlerInterceptor {

    @Override
    public void afterCompletion(HttpServletRequest arg0,
            HttpServletResponse arg1, Object arg2, Exception arg3)
            throws Exception {
    }

    @Override
    public void postHandle(HttpServletRequest arg0,
            HttpServletResponse response, Object arg2, ModelAndView arg3)
            throws Exception {
        response.sendRedirect("/webix/login.html");
    }

    @Override
    public boolean preHandle(HttpServletRequest request,
            HttpServletResponse response, Object handler) throws Exception {
        Object obj = request.getSession().getAttribute("LOGIN");
        if (null == obj) { // 未登錄
            if (request.getHeader("requestFlag") != null
                    && request.getHeader("requestFlag").equalsIgnoreCase(
                            "webix")) { // 如果是ajax請求響應頭會有,requestFlag
                response.setHeader("sessionstatus", "timeout");// 在響應頭設置session狀態
            } else {
                response.sendRedirect(request.getContextPath() + "/login");
            }
            return false;
        }
        return true;
    }

}

 

 4.2 spring配置文件加入攔截器配置

    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/mvc/*" />
            <bean class="com.ljx.filter.UserInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

 

 4.3 在F12控制台執行下webix.ajax查看效果

webix.ajax().get("/webix/mvc/login.action")

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 簡單的實現了 灰度,黑白,底片,模糊,馬賽克(代碼比較簡單,通過canvas實現的) 感覺挺有意思的,上面解釋很詳細,直接看代碼 ...
  • 第7章 jQuery插件的使用和寫法 插件又稱擴展,是一種遵循一定規範的應用程式介面寫出來的程式。 插件的編寫思想基於面向對象。 獲取最新的插件可以查看jquery官網: 本章將從幾個基本的例子來介紹jquery插件的使用。 一\. 表單驗證插件Validation jquery最常用的場合就是表單 ...
  • 一.綁定Class屬性。 綁定數據用v-bind:命令,簡寫成: 語法:<div v-bind:class="{ active: isActive }"></div>。class後面的雙引號里接受一個對象字面量/對象引用/數組作為參數, 這裡,{active: isActive}是對象參數,acti ...
  • 偽元素是一個好東西,但是很多人都沒怎麼用,因為他們覺得偽元素太詭異了。其實使用偽元素有很多好處,最大的好處是它可以簡化頁面的html標簽,同時用起來也很方便,善於使用偽元素可以讓你的頁面更加地簡潔優雅。 更好的閱讀體驗移步:http://yincheng.site/using-before-afte ...
  • 項目 (移動的廣告牌) 要求: 1,實現圖片一次以移動的方式出現,到最後一張完全出現時,回彈到第一張 2,滑鼠放在圖片上面圖片移動,滑鼠離開,圖片停止移動 *{ padding: 0; margin: 0;}/*添加背景圖片,個人愛好*/body{ background: url(../img/qu ...
  • 引言 webix.js被壓縮後很多字母不清楚是什麼用處,看源碼整理了部分出來,以button為例 1、button代碼 效果 2、以下代碼在F12的console中測試 define:方法(可以定義對象屬性的值) refresh:方法(刷新控制項) 效果 D 和 C:兩個都是定義屬性值的,define ...
  • 看到一些曾經只會灌水的網友,在學習了前端之後,已經能寫出下載量幾千幾萬的腳本、樣式,幫助大眾,成為受歡迎的人,感覺滿羡慕的。我也想學會前端技術,變得受歡迎呀。於是心血來潮,開始學習前端知識,並寫下了這個小練習。 基本思路是這樣的: 效果圖: 代碼如下: 點我進入線上版 這算是自己學習Javascri ...
  • 一:時間轉時間戳:javascript獲得時間戳的方法有四種,都是通過實例化時間對象 new Date() 來進一步獲取當前的時間戳 1.var timestamp1 = Date.parse(new Date()); // 結果:1477808630000 不推薦這種辦法,毫秒級別的數值被轉化為0 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...