AWS中使用CloudFront分发位于S3中的静态网站

这是其中一种方法,可有变化

假设主页为index.html

还要准备一个证书,要覆盖子域名(AWS Certificate Manager->Certificates)

1、S3->Create bucket->Bucket name(myweb)->Create bucket

2、S3->Buckets->myweb->Upload->Add files Add folder

3、CloudFront->Distributions->Create->Origin domain(myweb.s3.amazonows.com)->Name(myweb)->Origin access(Origin access control settings (recommended))->Origin access control->Create new OAC->复制到S3->Alternate domain name (CNAME) - optional-> Add item->(www.youweb.com)->Custom SSL certificate - optional(提前准备好 证书*)->*Create distribution

4、Amazon S3->Buckets->myweb->Permissions->Bucket policy->Edit->粘贴到S3

5、Route 53->Hosted zones->配置域名记录

6、问题:www.youweb.com不能访问,只能访问www.youweb.com/index.html

6.1、办法,CloudFront Functions:

6.2、CloudFront->Functions->Create function->Name(index)->Create function

javascript 复制代码
function handler(event) {
    var request = event.request;

    // 如果请求路径是根路径(/),重写为 /index.html
    if (request.uri === '/') {
        request.uri = '/index.html';
    }

    return request;
}

6.3、CloudFront->Functions->index->Publish->Publish function

6.4、CloudFront->Distributions->myweb->Behaviors->Edit->Function associations *- optional->Viewer request->*Function type->CloudFront Functions->Function ARN / Name(index)

相关推荐
kyriewen41 分钟前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
SmartBoyW2 小时前
深入ECMAScript规范:彻底搞懂JS隐式类型转换与底层ToPrimitive机制
前端·javascript
用户852495071842 小时前
解密 JavaScript 中的 this:谁才是真正的调用者?
javascript·面试
Heo2 小时前
Vite进阶用法详解
前端·javascript·面试
铁皮饭盒4 小时前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
小林ixn5 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript
东风破_5 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
巴勒个啦5 小时前
D3.js 入门实战:用力导向图可视化项目依赖关系
javascript
不好听6136 小时前
JavaScript 的 this 到底指向谁?
javascript·面试
触底反弹6 小时前
🔥 2026 年爆火的 Harness Engineering 到底是什么?从原理到实战一文讲透
javascript·人工智能·程序员