js ajax请求cookie,通过HTTPS的HTTP Cookies和Ajax请求

我知道以前已经以各种形式询问过这个问题,但是我似乎无法解决这个问题。我尝试使用jQuery和本机JS API发出Ajax请求。

我的情况如下(参见附图):

浏览器发出HTTP请求

服务器响应并设置持久性Cookie

浏览器发出HTTP Ajax请求,Cookie在那里

服务器响应预期,更新Cookie

浏览器发出HTTPS Ajax请求,Cookie不再存在(?!)

由于没有Cookie(意外行为),服务器会给出“默认”响应

在任何人开始关于跨域请求的讲座之前,我先说几件事:

我知道这是一个跨域请求(不同的协议),这就是服务器Access-Control-Allow-Origin在响应中设置标头的原因(并且我使用的是Chrome和Firefox,两者均支持CORS)

不过,我还知道,因为主机是相同的,所以HTTP cookie应该可以通过HTTPS进行管理(请参阅此处)。

(编辑)已为常规域(例如.domain.ext)正确设置了cookie,并且未设置HttpOnly和Secure标志

那么,为什么,为什么,为什么浏览器在进行HTTPS Ajax调用时不传递cookie?有任何想法吗?我将失去理智…

+-----------+ HTTP Request +-----------+

|Browser |+---------------->|Server |

+-----------+ +-----------+

HTTP Response

Set-cookie

Ajax HTTP Req.

+---------------->

Cookie (OK)

HTTP Response

Set-cookie (OK)

Ajax HTTPS Req.

+---------------->

No Cookie (!!!)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值