【发布时间】:2021-03-17 01:33:45
【问题描述】:
我正在从两个不同的域访问 CloudFront。我将 S3 配置为允许来自两个域的跨域。来自 mydomain1 的页面会正确获取数据,然后来自 mydomain2 的页面会正确发送请求:
> origin: https://mydomain2
CloudFront 回复:
< content-type: application/json
< content-length: 65
< date: Fri, 04 Dec 2020 22:45:50 GMT
< access-control-allow-origin: https://mydomain1
< access-control-allow-methods: GET, PUT
< access-control-allow-credentials: true
< accept-ranges: bytes
< server: AmazonS3
< x-cache: Hit from cloudfront
当然,浏览器阻止了这个请求,因为允许的来源不匹配
我最初认为我的 Origin Request Policy 错误,但不,我使用的是 Managed-CORS-S3Origin,它具有正确的 name,我检查了它,它说它通过了沿着 Origin 标头到 S3 源——问题并没有因为内容分发业务中的“源”与 HTTP 业务中的含义大不相同这一事实而变得更容易。
但很明显,Access-Control-Allow-Origin 响应标头的值 出于某种原因被缓存。
【问题讨论】:
标签: amazon-s3 cors amazon-cloudfront