ajax跨域重定向

前端代码,在全局页面中写道:

<script type="text/javascript">
    $.ajaxSetup({
		//设置ajax请求结束后的执行动作
		complete : function(XMLHttpRequest, textStatus) {
			// 通过XMLHttpRequest取得响应头,sessionstatus
			var sessionstatus = XMLHttpRequest.getResponseHeader("sessionstatus");
			if (sessionstatus == "TIMEOUT") {
				Tip.info("长时间未操作,正在前往登录页...");
				setTimeout(function(){  //使用  setTimeout()方法设定定时2000毫秒
					var win = window;
					while (win != win.top) {
						win = win.top; // 避免弹框层中转向登录页的情况
					}
					win.location.href = XMLHttpRequest.getResponseHeader("CONTEXTPATH");
				},2000);
			}
		}
	});
</script>

后台代码,在拦截请求时写道:

String type = request.getHeader("X-Requested-With");
if (StringUtils.equals("XMLHttpRequest", type)) {
    // ajax请求
    response.setHeader("SESSIONSTATUS", "TIMEOUT");
    response.setHeader("CONTEXTPATH", redirectUrl);
    response.setStatus(HttpServletResponse.SC_FORBIDDEN);
} else {
     response.sendRedirect(redirectUrl);
}

// redirectUrl就是你要重定向的路径

假如你这样写还是不能跳转的话,那你就继续去找解决办法吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值