色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

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

瀏覽:105日期: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
主站蜘蛛池模板: 亚洲欧美国产精品久久久 | 国产一级毛片视频 | 国产一级片毛片 | 久久成人免费 | 男人天堂视频网 | 老司机午夜在线视频免费观 | 国产 magnet| 青青草国产免费国产是公开 | 色妇女影院 | 成人a毛片手机免费播放 | 免费国产成人高清在线观看视频 | 日韩第五页 | 美女福利视频午夜在线 | 亚洲一区二区在线成人 | 久久久一本精品99久久精品66 | 国产高颜值露脸在线观看 | 欧美怡红院在线观看 | 国产成人tv在线观看 | 黄www片 | 寡妇野外啪啪一区二区 | 美国毛片毛片全部免费 | 亚洲欧洲一区二区三区在线 | 久草青青 | 91热国产 | 欧美a级毛片免费播敢 | 欧美一区二区三区在观看 | 日韩精品一区二区三区 在线观看 | 国产精品国产亚洲精品看不卡 | 亚洲国产第一 | 韩国三级 mp4 | 综合激情网站 | 夜夜春夜夜夜夜猛噜噜噜噜噜 | 久久zyz| 怡红院在线a男人的天堂 | 免费观看欧美精品成人毛片 | free性丰满白嫩白嫩的hd | 日本vs欧美一区二区三区 | 亚洲国产欧洲精品路线久久 | 在线看片 在线播放 | 亚洲精品一区二区在线播放 | 国产原创在线视频 |