解决AJAX请求由于跨域session改变的问题

公司项目进行了https升级改造,然后发现一个问题。后台请求中需要获取session中的用户信息,但是在登陆后发现session中的用户信息都没有了。原因是单点登录时请求的是https,但是AJAX请求时使用的是http,这样就造成了跨域,浏览器会新建一个sessionId,相当于之前session中的信息就没有了。
解决方法:
AJAX请求中有一个属性xhrFields,该属性可以添加到原生xhr对象上的key/value对上。这样我们就可以设置withCredentials:true来使跨域请求携带cookie,依旧享受同源策略。

注:若要使用此方法,需要使用jQuery1.5.1及以上版本。

例:

$.ajax({
    url: url,
    dataType: "json",
    xhrFields:{
        withCredentials:true
    },
    data: data,
    type: "GET",
    async: true,
    success: function (data) {
    
    }
});

补充

如果使用的是XMLHttpRequest 对象,同样也可以设置。

var xmlHttpRequest = new XMLHttpRequest();
//参数为:请求方式、调用url、是否异步
xmlHttpRequest.open("GET",url,true);
//设置withCredentials
xmlHttpRequest.withCredentials = true;
xmlHttpRequest.send(null);
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值