午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

java - AJAX 請求時,SpringMVC 攔截器無法獲得 session 中的值

瀏覽:180日期:2024-02-02 16:52:08

問題描述

攔截器代碼(想實現的功能就是如果當前 Session 中有 user,那么就可以訪問頁面和使用 AJAX 請求):

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; }}

該攔截器攔截了所有的方法(/**),對于返回 ModelAndView 的控制器方法對應的路徑,攔截器可以正常獲得 session 的值;但是對于 AJAX 訪問的控制器方法(被 @ResponseBody 注解的方法)對應的路徑,攔截器卻無法獲得 session 的值。請問這是什么原因呢,解決辦法是什么?

問題解答

回答1:

SpringMVC攔截ajax請求時,response.sendRedirect不能正常跳轉。你可以判斷是否為ajax請求,如果是,給前臺返回一個信息,前臺收到后跳到登錄頁。

@Overridepublic boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(); if (session.getAttribute('user') != null) {return true; } // 如果是ajax請求,請求頭會有x-requested-with String requestWith = request.getHeader('x-requested-with'); if (requestWith != null && requestWith.equalsIgnoreCase('XMLHttpRequest')){ServletOutputStreamout = rep.getOutputStream();out.print('unlogin');//返回給前端頁面的未登陸標識out.flush();out.close(); } else {response.sendRedirect('/WEB-INF/views/page/user/login.jsp'); } return false;}

標簽: java
主站蜘蛛池模板: 毛片手机在线 | 欧美午夜影院 | 在线视频一区二区三区 | 日本精品在线播放 | 全部免费毛片在线播放 | 在线中文视频 | 亚日韩 | 国产精品一区二区在线观看 | 4虎最新网址 | 在线免费黄色网址 | 亚洲美女网站 | 日韩久久久 | 亚洲激情国产 | 色欧美片视频在线观看 | www.av天天| 日韩影视一区二区三区 | 成人a在线观看 | 日韩av在线一区 | 开心春色激情网 | 青青草视频成人 | 激情一级片 | 日本在线二区 | 国产97色 | 牛牛视频在线 | 欧美一区二区三区精品 | 香蕉视频免费在线播放 | 久久婷婷网| 伊人网综合视频 | 欧美日韩精品一二三区 | 99热这里有精品 | 国产69精品久久久久久久久久 | 国内偷拍久久 | 婷婷色吧 | 免费成年人视频在线观看 | 亚洲精品视频久久 | 中字av在线 | 日韩乱码一区二区 | 亚洲一区二区视频 | 免费人成在线观看 | 国产综合亚洲精品一区二 | 九九九视频在线观看 |