av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

瀏覽:96日期: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
主站蜘蛛池模板: 狠狠的操| 一区二区三区在线电影 | 日韩一区二区三区精品 | 久草在线视频中文 | 91看片在线观看 | 超碰97免费在线 | 草草草影院 | 狠狠操电影 | 国产精品日韩欧美 | 一区二区三区小视频 | 久久久国产一区二区三区四区小说 | h视频免费观看 | 成人超碰| 伊人网站在线 | 午夜色婷婷| 乱一性一乱一交一视频a∨ 色爱av | 国产性色视频 | 久久国内精品 | 久久久久久久一区二区三区 | av片免费 | 成人国产一区二区三区精品麻豆 | 久久久久久高清 | 亚洲国产成人精品久久久国产成人一区 | 欧美一区二区在线观看 | 亚洲激情第一页 | 久久国产一区二区 | 中文字幕在线免费 | 91xx在线观看 | 好婷婷网| 欧美激情一区二区 | 欧美不卡一区二区三区 | 一级毛片免费视频观看 | 精品美女视频在线观看免费软件 | 欧美日韩中文在线观看 | 一区免费视频 | 中文字幕第5页 | 男女羞羞的网站 | 在线久草| 男人的天堂久久 | 成人精品免费视频 | 国产伊人久久久 |