国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:81日期: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
主站蜘蛛池模板: 一级片视频在线 | 欧美a级在线观看 | 毛片手机在线观看 | 国产人人插 | 99re5久久在热线播放 | 亚洲综合久久久久久中文字幕 | 精品热线九九精品视频 | 欧美刺激午夜性久久久久久久 | 日韩特黄特色大片免费视频 | 99久久99久久久99精品齐 | 亚洲日产综合欧美一区二区 | 在线はじめてのおるすばん | 国产一区二区福利久久 | 久久香蕉国产线看观看亚洲片 | 成年人免费的视频 | 久久精品国产亚洲高清 | 韩国黄色一级毛片 | 国产精品三级在线播放 | 亚洲三级在线看 | 久草三级| 欧美成人精品第一区 | 日韩第五页 | 久久国产三级精品 | 国产精品亚洲高清一区二区 | 亚洲第十色 | 免费看黄色三级毛片 | 久久精品国产亚洲 | 精品理论片一区二区三区 | 99国产精品视频久久久久 | 国产日韩欧美视频在线 | 国产农村乱子伦精品视频 | 日本一区不卡视频 | 在线看黄网址 | 日韩乱码视频 | 91香蕉视频网 | 高颜值美女啪啪 | 欧美日韩视频在线 | 国产区在线免费观看 | 国产成人精品精品欧美 | 国产伦码精品一区二区 | 在线免费观看毛片网站 |