Cloudfront:设置与 Origin 的 s3 路径差异
Posted
技术标签:
【中文标题】Cloudfront:设置与 Origin 的 s3 路径差异【英文标题】:Cloudfront: setting s3 path difference from Origin 【发布时间】:2017-02-21 00:00:56 【问题描述】:缓存行为设置,我用
s3/*
将请求重定向到 s3 文件夹,但我不想将我的图像放在名为 s3 的文件夹下,而是放在 s3 存储桶下,以便像这样重定向:
xxxx.cloudfront.com/s3/images/1.png -> bucket_name/images/1.png
不是
xxxx.cloudfront.com/s3/images/1.png -> bucket_name/s3/images/1.png
请帮我看看如何这样配置。
【问题讨论】:
【参考方案1】:您可以这样做with lambdas 这是相关的 lambda sn-p。
exports.handler = (event, context, callback) =>
// this is the request we want to re-map
var request = event.Records[0].cf.request;
// the request has a 'uri' property which is the value we want to overwrite
// rewrite the url applying your custom logic
request.uri = 'some custom logic here to rewrite the url';
// quit the lambda and let the request chain continue
callback( null, request );
;
【讨论】:
【参考方案2】:我认为这是不可能的。源路径可以重定向到子目录(例如 index.htm
-> production/index.htm
),但 CloudFront 无法去除路径部分。
查看文档:Origin Path
一些选项:
使用单独的分发版,而不是在路径前加上s3
只需将s3/
放在文件名的前面(并实际使用完整路径)
【讨论】:
【参考方案3】:很遗憾,这是不可能的。 Cloudfront 会将确切的请求路径映射回源。它为操作原始路径提供的唯一选项是添加前缀 - 它不允许从路径中删除任何内容。
Origin Path 包含有关 Origin 路径设置的详细信息 - 但您会从该页面看到没有删除请求路径任何部分的选项。
【讨论】:
以上是关于Cloudfront:设置与 Origin 的 s3 路径差异的主要内容,如果未能解决你的问题,请参考以下文章
来自 S3 Origin 的 Cloudfront 响应不断更改 CORS 标头
CloudFront 和 EC2 Origin 之间的 SSL 证书使用啥 Origin 和 ServerName?
Chrome S3 Cloudfront:初始和加载请求上没有“Access-Control-Allow-Origin”标头
Cloudfront 的 Terraform:InvalidHeadersForS3Origin,但我没有将 [*] 传递给任何 S3 源