标签:拦截器 请求 SpringMVC request window ajax session 跳转
背景
在实现了一个用户登录的拦截器后,判断session中是否存在用户的id,如果没有就跳转到登录界面,如果有就放行,发现这样对ajax请求没有作用,那么如何对ajax请求拦截后进行页面跳转呢?首先判断是否是ajax请求,如果是ajax请求就输出一个标志,然后再success中判断这个标志,然后根据标志在前端利用 window.location.href 进行页面的跳转
具体实现
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession();
Integer uid = (Integer) session.getAttribute("id");
String uri = request.getRequestURI();
if (uri.contains("login") || uri.contains("register")) {
return true;
}
if (uid == null) {
// 判断是否是ajax请求
String XRequested =request.getHeader("X-Requested-With");
if("XMLHttpRequest".equals(XRequested)) {
response.getWriter().write("FAILURE");
} else {
request.setAttribute("msg", "请登录后再操作");
request.getRequestDispatcher("/login.jsp").forward(request, response);
}
return false;
}
return true;
}
$.ajax({
url : "user/updateHeader",
type : "POST",
data : "base64=" + base64,
async : true,
success : function (msg) {
if (msg === "SUCCESS") {
alert("上传成功");
window.location.href = "index.jsp";
} else {
alert("上传失败,请登录后尝试");
window.location.href = "login.jsp";
}
}
})
标签:拦截器,请求,SpringMVC,request,window,ajax,session,跳转 来源: https://blog.csdn.net/qq_45758686/article/details/116464008
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。