使用ajax转发请求后服务器端无法重定向的原因及解决方案

原因

ajax处于前端和后端之间,当使用ajax之后,后端的重定向请求会传到ajax,ajax只接收内容,不做任何操作。

解决方法

首先在后端定义一个函数,修改response头部信息。

public void ajaxRedirect(HttpServletRequest request, HttpServletResponse response, String page) throws IOException {
        if ("XMLHttpRequest".equals(request.getHeader("X-Requested-With"))) {
            response.setHeader("REDIRECT", "REDIRECT"); //表示重定向
            response.setHeader("CONTEXTPATH", request.getContextPath() +"/"+page); //重定向的路径
            response.setStatus(HttpServletResponse.SC_FORBIDDEN); //拒绝访问.
        } else {
            response.sendRedirect(request.getContextPath() +"/"+page);
        }
    }

然后将resp.sendRedirect()命令改为上述函数

//resp.sendRedirect(successPage);
ajaxRedirect(req, resp, successPage);

在前端,定义一个setAjax.js文件,内容如下:

$.ajaxSetup( {  
	    //设置ajax请求结束后的执行动作  
	    complete : function(XMLHttpRequest, textStatus) {
	        // 通过XMLHttpRequest取得响应头,REDIRECT  
	        var redirect = XMLHttpRequest.getResponseHeader("REDIRECT");//若HEADER中含有REDIRECT说明后端想重定向
	        if (redirect == "REDIRECT") {
	            var win = window;  
	            while (win != win.top){
	                win = win.top;
	            }
	          //将后端重定向的地址取出来,使用win.location.href去实现重定向的要求
	          win.location.href= XMLHttpRequest.getResponseHeader("CONTEXTPATH");  
	        }
	    }  
	});

然后在页面中引用此文件

<script src="setAjax.js"></script>

搞定!

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值