作web開發時,當session超時時,若是不是ajax請求,很簡單就能實現跳到指定的頁面。可是ajax請求就會有問題。session超時的時候,點擊到ajax請求就會彈出一些頁面源碼文件。java
首先建了個攔截器,來判斷session超時。用戶登陸後會保存用戶信息在一個session裏,在session的監聽裏,session超時會銷燬保存在session裏的用戶信息,而攔截器就經過session裏是否有用戶信息來判斷session超時。jquery
攔截器是spring-mvc的攔截器,在攔截器裏判斷是否是ajax請求:web
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()+"/account/login"); } return false; } return super.preHandle(request, response, handler); } }
這樣,若是session超時,並且是ajax請求,就會在響應頭裏,sessionstatus有一個timeout;ajax
再用一個全局的方法來處理,session超時要跳轉的頁面。
spring
jquery 能夠用$.ajaxSetup 方法,ext也有相似的方法spring-mvc
$.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 + "account/login"); } } });