Ajax重定向处理

Ajax请求如何重定向

背景

在前端使用Ajax请求,后端使用HttpServletResponse.sendRedirect(“URL”);的情况下,页面并未发生跳转,这是为什么呢?

原因

默认ajax是不支持重定向的,因为ajax本身就是局部刷新,不重新加载页面的。

解决方法

后端java设置重定向Header

HttpServletResponse response = CommonUtils.getHttpServletResponse();
HttpServletRequest request = CommonUtils.getHttpServletRequest();
//告诉ajax我要重定向
response.setHeader("REDIRECT", "REDIRECT");
//告诉ajax我重定向的路径
response.setHeader("CONTENTPATH", loginJumpUrl + "&NextAction=" + URLEncoder.encode(request.getHeader("referer"), "utf8"));

前端common.js全局设置ajax请求完成后处理逻辑

//设置全局ajax处理逻辑
$.ajaxSetup({
    //设置ajax请求结束后的执行动作
    complete: function (xhr) {
        // 通过XMLHttpRequest取得响应头,sessionstatus
        if("REDIRECT" == xhr.getResponseHeader("REDIRECT")){ //若HEADER中含有REDIRECT说明后端想重定向,
            var win = window;
            while(win != win.top){
                win = win.top;
            }
            win.location.href = xhr.getResponseHeader("CONTENTPATH");//将后端重定向的地址取出来,使用win.location.href去实现重定向的要求
        }
    }
});
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值