java - AJAX 請(qǐng)求時(shí),SpringMVC 攔截器無法獲得 session 中的值
問題描述
攔截器代碼(想實(shí)現(xiàn)的功能就是如果當(dāng)前 Session 中有 user,那么就可以訪問頁面和使用 AJAX 請(qǐng)求):
public class UserLoginInterceptor extends HandlerInterceptorAdapter { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {HttpSession session = request.getSession();if (session.getAttribute('user') != null) { return true;}request.getRequestDispatcher('/WEB-INF/views/page/user/login.jsp').forward(request, response);return false; }}
該攔截器攔截了所有的方法(/**),對(duì)于返回 ModelAndView 的控制器方法對(duì)應(yīng)的路徑,攔截器可以正常獲得 session 的值;但是對(duì)于 AJAX 訪問的控制器方法(被 @ResponseBody 注解的方法)對(duì)應(yīng)的路徑,攔截器卻無法獲得 session 的值。請(qǐng)問這是什么原因呢,解決辦法是什么?
問題解答
回答1:SpringMVC攔截ajax請(qǐng)求時(shí),response.sendRedirect不能正常跳轉(zhuǎn)。你可以判斷是否為ajax請(qǐng)求,如果是,給前臺(tái)返回一個(gè)信息,前臺(tái)收到后跳到登錄頁。
@Overridepublic boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(); if (session.getAttribute('user') != null) {return true; } // 如果是ajax請(qǐng)求,請(qǐng)求頭會(huì)有x-requested-with String requestWith = request.getHeader('x-requested-with'); if (requestWith != null && requestWith.equalsIgnoreCase('XMLHttpRequest')){ServletOutputStreamout = rep.getOutputStream();out.print('unlogin');//返回給前端頁面的未登陸標(biāo)識(shí)out.flush();out.close(); } else {response.sendRedirect('/WEB-INF/views/page/user/login.jsp'); } return false;}
