解决后台session失效前端不能自动跳转登录页面的问题

后台在session失效时会往responseHeader里添加一个sessionstatus的属性,值为timeout,还会设置重新跳转登录页面的地址redirectUrl

代码

if (httpRequest.getHeader("x-requested-with") != null
							&& httpRequest.getHeader("x-requested-with").equals("XMLHttpRequest")) { // ajax请求
						httpResponse.setHeader("sessionstatus", "timeout");
						httpResponse.setHeader("redirectUrl", url_redirect);
					} else {
						httpResponse.sendRedirect(url_redirect);
					}

前端如果用到axios,需要给requestHeader配置x-requested-with属性,值为XMLHttpRequest,主要是为了配合后端设置sessionstatus=timeout

axios配置代码

axios.interceptors.request.use(config => {
        if (true) {
            config.headers.common["X-Requested-With"] = "XMLHttpRequest";
        }
        return config;
    },
    err => Promise.reject(err)
);
axios.interceptors.response.use(config => {
        console.log(config.headers);
        if (config.headers["sessionstatus"]) {
            // config.headers.common["X-Requested-With"] = "XMLHttpRequest";
            console.log(config.headers["sessionstatus"]);
            console.log("過期");
            window.location = config.headers["redirectUrl"];
            //这里直接跳转后端设置的登录页面地址
        }
        else {
            console.log("未過期");
        }
        return config;
    },
    err => Promise.reject(err)
);

ajax配置代码

$(function () {
    $.ajaxSetup({
        complete:function(XMLHttpResponse,textStatus){
            var sessionstatus = XMLHttpResponse.getResponseHeader("sessionstatus");
            if (sessionstatus == "timeout") {
                // 这里怎么处理在你,这里跳转的登录页面
                window.location.replace(XMLHttpResponse.getResponseHeader("redirectUrl"));
            }
        }
    });
})
// 这个$(function(){})是为了让ajaxSetup配置执行一遍,后续ajax才会使用这些配置

这两段配置都写成了单独的js文件
引入jq和axios后再引入这两个配置文件就行了

上面有些打印语句和没必要的判断大家可以自己去掉,先这样,下次见

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值