Pet*_* G. 7 caching amazon-s3 amazon-web-services amazon-cloudfront aws-lambda
这是一个 CDN 架构,用于调整图像大小并通过 AWS CloudFront 为其提供服务:
如果在 S3 存储桶中找不到图像,它会发出307 临时重定向(而不是 404)以通过 API 网关访问 Lambda。Lambda 调整图像大小(基于来自 S3 存储桶的原始图像)并将其上传到 S3 存储桶。浏览器再次永久重定向到带有新生成图像的 S3 存储桶。
当我想通过 CloudFront 访问相同的图像时,我收到403 Forbidden错误。它来自 S3 或 CloudFront。正如状态所示,这可能与访问权限有关。
为什么将 CloudFront 添加到工作请求链中会导致 403 错误?
什么工作:
https://{bucket}.s3-website-{region}.amazonaws.com/100x100/image.jpg
HTTP/1.1 307 Temporary Redirect
x-amz-id-2: xxxx
x-amz-request-id: xxxx
Date: Sat, 19 Aug 2017 15:37:12 GMT
Location: https://{gateway}.execute-api.{region}.amazonaws.com/prod/resize?key=100x100/image.jpg
Content-Length: 0
Server: AmazonS3
https://{gateway}.execute-api.{region}.amazonaws.com/prod/resize?key=100x100/image.jpg
HTTP/1.1 301 Moved Permanently
Content-Type: application/json
Content-Length: 0
Connection: keep-alive
Date: Sat, 19 Aug 2017 15:37:16 GMT
x-amzn-RequestId: xxxx
location: http://{bucket}.s3-website-eu-west-1.amazonaws.com/100x100/image.jpg
X-Amzn-Trace-Id: xxxx
X-Cache: Miss from cloudfront
Via: 1.1 {distribution}.cloudfront.net (CloudFront)
X-Amz-Cf-Id: xxxx
http://{bucket}.s3-website-{region}.amazonaws.com/100x100/image.jpg
HTTP/1.1 200 OK
x-amz-id-2: xxxx
x-amz-request-id: xxxx
Date: Sat, 19 Aug 2017 15:37:18 GMT
Last-Modified: Sat, 19 Aug 2017 15:37:17 GMT
x-amz-version-id: null
ETag: xxxx
Content-Type: image/png
Content-Length: 20495
Server: AmazonS3
Run Code Online (Sandbox Code Playgroud)
什么不起作用:
https://{distribution}.cloudfront.net/100x100/image.jpg
HTTP/1.1 403 Forbidden
Content-Type: application/xml
Transfer-Encoding: chunked
Connection: keep-alive
Date: Sat, 19 Aug 2017 15:38:24 GMT
Server: AmazonS3
X-Cache: Error from cloudfront
Via: 1.1 {distribution}.cloudfront.net (CloudFront)
X-Amz-Cf-Id: xxxx
Run Code Online (Sandbox Code Playgroud)
我已将 S3 存储桶作为源添加到 CloudFront
该错误是由于使用 REST 端点(例如 s3.amazonaws.com)实现类似网站的功能(重定向、html 错误消息和索引文档)而引起的。这些功能仅由网站端点(例如bucketname.s3-website-us-east-1.amazonaws.com)提供。
http://docs.aws.amazon.com/AmazonS3/latest/dev/WebsiteEndpoints.html
这让我很困惑,因为在创建 CloudFront 发行版时,REST 端点是通过控制台中的自动完成功能提供的。必须手动输入正确的端点。