Ajax請求session逾時處理流程(DWZ)

來源:互聯網
上載者:User

DWZ-Java架構Ajax請求session逾時處理思路:
    1)SessionValidateFilter統一驗證session是否逾時
    2)SessionValidateFilter中判斷請求是否為ajax請求
    3)ajax請求session逾時返回一個json {"statusCode":"301", "message":"Session Timeout! Please re-sign in!"}
    4)dwz js架構根據statusCode==301,處理是跳轉到登陸頁面或者彈出登入dialog

-------------------------------------------------------------------

java伺服器端處理:
    SessionValidateFilter中修改:    

if ("XMLHttpRequest".equalsIgnoreCase(request.getHeader("X-Requested-With")) || request.getParameter("ajax") != null) {
PrintWriter out = response.getWriter();
out.println({"statusCode":"301", "message":"Session Timeout! Please re-sign in!"});
} else {
response.sendRedirect(response.encodeRedirectURL(this.loginUrl + java.net.URLEncoder.encode(backToUrl, "UTF-8")));
}

-------------------------------------------------------------------

js用戶端處理:

session逾時跳轉到登陸頁面還是彈出登入dialog,在DWZ UI初始化時設定:

<script type="text/javascript">
$(function(){
DWZ.init("dwz.frag.xml", {
// loginUrl:"loginsub.html", loginTitle:"登入", // 彈出登入對話方塊
loginUrl:"login.html", // 跳到登入頁面
statusCode:{ok:200, error:300, timeout:301}, //【可選】
pageInfo:{pageNum:"pageNum", numPerPage:"numPerPage", orderField:"orderField", orderDirection:"orderDirection"}, //【可選】
debug:false, // 偵錯模式 【true|false】
callback:function(){
initEnv();
$("#themeList").theme({themeBase:"themes"});
}
});
});
</script>

ajax load頁面片段處理:

    ajax請求統一使用dwz的loadUrl()方法,不能使用jquery內建的load().
    當用戶端調用loadUrl()並且session逾時了,跳轉到登陸頁面或者彈出登入dialog。
    session逾時彈出登入dialog注意事項:
        用一個帶屏蔽層的dialog覆蓋的整個瀏覽器.這時瀏覽器視窗內容不能變,只是上面加了一個登入框和一個背景層。
        當使用者輸入username and password登入成功後,去掉登入框和背景層.這時使用者可以繼續操作.
        登入失敗alert出錯資訊,瀏覽器視窗內容還是不變.
    參考dwz.core.js程式碼片段

  

  loadUrl: function(url,data,callback){
var $this = $(this);

$.ajax({
type: 'POST',
url: url,
cache: false,
data: data,
success: function(response){
var json = DWZ.jsonEval(response);
if (json.statusCode==DWZ.statusCode.timeout){
alertMsg.error(DWZ.msg("sessionTimout"), {okCall:function(){
DWZ.loadLogin();
}});
} if (json.statusCode==DWZ.statusCode.error){
if (json.message) alertMsg.error(json.message);
} else {
$this.html(response).initUI();
if ($.isFunction(callback)) callback(response);
}
},
error: DWZ.ajaxError
});
}

ajax post 表單資料處理:
   
    當用戶端ajax提交表單超原理同ajax load
    參考dwz.core.js程式碼片段

  ajaxDone:function (json){
if(json.statusCode == DWZ.statusCode.error) {
if(json.message && alertMsg) alertMsg.error(json.message);
} else if (json.statusCode == DWZ.statusCode.timeout) {
if(json.message && alertMsg) alertMsg.error(json.message, {okCall:DWZ.loadLogin});
else DWZ.loadLogin();
} else {
if(json.message && alertMsg) alertMsg.correct(json.message);
};
}

-------------------------------------------------------------------

注意事項:
    ajax請求session逾時伺服器端返回一個json就可以了,其他的就交給dwz js架構來處理,伺服器端只要做到ajax請求session逾時返回如下json就可以了:

{"statusCode":"301", "message":"Session Timeout! Please re-sign in!"}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.