ajax请求重定向

来源:互联网 发布:质量好的淘宝女装店 编辑:程序博客网 时间:2024/04/27 22:40

一、ajax重定向的问题。

默认ajax是不支持重定向的,因为ajax本身就是局部刷新,不重新加载页面的。如果需要用到重定向可以通过以下方法:

第一步:后端代码改造。

在后端(大部分情况都是拦截器)中判断是否需要重定向。

Eg:session过期判断,当判断session已经过期了,就先判断此次请求是否是ajax的请求。

方法:

@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object arg2) throws Exception {
User u = (User) request.getSession().getAttribute("USER");
String type = request.getHeader("X-Requested-With");// XMLHttpRequest
if (u == null) {
// 重定向
String path = request.getContextPath();
String basePath = request.getScheme() + "://"+ request.getServerName() + ":" + request.getServerPort()+ path + "/";
//response.sendRedirect(contextPath+"/index.jsp");
// System.err.println("sendRedirect");
// 转发
if (StringUtils.equals("XMLHttpRequest", type)) {
// ajax请求
response.setHeader("SESSIONSTATUS", "TIMEOUT");

response.setHeader("CONTEXTPATH", basePath+"index.jsp");

response.setStatus(HttpServletResponse.SC_FORBIDDEN);
return false;

} else {
response.sendRedirect(basePath+"index.jsp");
return false;
}
}
return true;
}

第二步:前段改造ajax属性。

通过$.ajaxSetup()方法给ajax方法统一添加请求执行结束后,执行的操作。

$.ajaxSetup( {
//设置ajax请求结束后的执行动作
complete : 
function(XMLHttpRequest, textStatus) {
// 通过XMLHttpRequest取得响应头,sessionstatus
var sessionstatus = XMLHttpRequest.getResponseHeader("sessionstatus");
if (sessionstatus == "TIMEOUT") {
var win = window;
while (win != win.top){
win = win.top;
}
win.location.href= XMLHttpRequest.getResponseHeader("CONTEXTPATH");
}
}
});

 

备注:这个方法需要引入,所以建议将这个方法放在公共的js中。

1 0
原创粉丝点击