做web開發時,當session超時時,如果不是ajax請求,很簡單就能實現跳到指定的頁面。但是ajax請求就會有問題。session超時的時候,點擊到ajax請求就會彈出一些頁面源碼文件。
?首先建了個攔截器,來判斷session超時。用戶登錄后會保存用戶信息在一個session里,在session的監聽里,session超時會銷毀保存在session里的用戶信息,而攔截器就通過session里是否有用戶信息來判斷session超時。
?攔截器是spring-mvc的攔截器,在攔截器里判斷是不是ajax請求:
public class LoginInterceptor extends HandlerInterceptorAdapter{ public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { Object obj = request.getSession().getAttribute(SecurityConstants.LOGIN_USER); if (null == obj) { //未登錄 if (request.getHeader("x-requested-with") != null && request.getHeader("x-requested-with").equalsIgnoreCase("XMLHttpRequest")){ //如果是ajax請求響應頭會有,x-requested-with response.setHeader("sessionstatus", "timeout");//在響應頭設置session狀態 }else{ response.sendRedirect(request.getContextPath()+"/login.jsp"); } return false; } return super.preHandle(request, response, handler); } }
這樣,如果session超時,而且是ajax請求,就會在響應頭里,sessionstatus有一個timeout;
再用一個全局的方法來處理,session超時要跳轉的頁面。
jquery?可以用$.ajaxSetup?方法,ext也有類似的方法
$.ajaxSetup({ contentType:"application/x-www-form-urlencoded;charset=utf-8", complete:function(XMLHttpRequest,textStatus){ var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus"); //通過XMLHttpRequest取得響應頭,sessionstatus, if(sessionstatus=="timeout"){ alert("登錄超時,請重新登錄!"); //如果超時就處理 ,指定要跳轉的頁面 window.location.replace(webPath.webRoot + "/login.jsp"); } } });