Amazon Simple Storage Service (S3) 以其擴展性、耐用性及安全性聞名,是託管靜態網站的絕佳選擇。這些網站通常由 HTML、CSS 和 JavaScript 文件組成,可以直接從 S3 Bucket 提供服務,這是一種簡單且經濟實惠的託管解決方案。
您只需將 HTML、CSS、圖片及 JavaScript 文件上傳到 S3 Bucket,即可存取靜態網站。然而,S3 提供了一種特定方式,讓靜態網站的功能超越直接存取物件的層級。在本文中,我們將學習如何將您的 S3 Bucket 轉換為靜態網站。
先決條件
在開始之前,請確保您具備以下條件:
一個啟用的 AWS 帳戶
已建立的 S3 Bucket
靜態網站文件(HTML、CSS、圖片或 JS)
如果您是 AWS 和雲端運算的新手,建議您參考以下關於 AWS 和 S3 的文章:
啟用 S3 Bucket 的公共存取
前往您的 S3 Bucket。
data:image/s3,"s3://crabby-images/b7c21/b7c21b48dbb114afc42f76e2b7d2ae7156af5c91" alt="Enabling Public Access to Your S3 Bucket"
點擊 Bucket 內的「Permissions(權限)」標籤。
data:image/s3,"s3://crabby-images/e5934/e593499aed4ef2991871e4049f510acd840cf187" alt="Go to permission tab"
預設情況下,您會看到已全面封鎖公共存取。
data:image/s3,"s3://crabby-images/3566d/3566dde13b3e0a3001c77acc818813f58f31d2e2" alt="Click on edit"
點擊「Edit(編輯)」按鈕,取消勾選「Block all public access(封鎖所有公共存取)」選項,然後點擊「Save changes(儲存變更)」。
data:image/s3,"s3://crabby-images/9a40c/9a40c40103e52e21701ca488358068e5e13cb1a2" alt="Uncheck the box, to make bucket public"
系統會要求您確認。輸入「confirm」,然後點擊「Confirm」按鈕。
data:image/s3,"s3://crabby-images/ca31b/ca31b46a28653ff9764d1186c6b9b5e2f2ecb977" alt="confirm and save"
接著,向下滾動到「Bucket Policy(存取策略)」部分,點擊「Edit」。
data:image/s3,"s3://crabby-images/36644/36644f97d4b6306f8ef4dc423dc753aa9177cf17" alt="Click on edit to add bucket policy"
點擊「Policy generator(策略產生器)」按鈕,將跳轉至 AWS 策略產生器網頁。
data:image/s3,"s3://crabby-images/2597c/2597cedd965ec8c9d84c6cf6fe91d23873564706" alt="click on "Policy generator""
第一步,選擇策略類型為「S3 Bucket Policy」。
data:image/s3,"s3://crabby-images/600aa/600aa30f305f380dd42db312e8211bd3db978969" alt="select the policy type to s3"
第二步,在「Add Statements(新增陳述句)」部分,選擇:
Effect(效果):選擇「allow」
Principal(主體):輸入「*」
Action(動作):選擇「GetObject」
此操作允許他人從您的 S3 Bucket 存取文件。
data:image/s3,"s3://crabby-images/f5e86/f5e86b47f916cb1717cdd298d732e796cde301dc" alt="Add the statements shown"
返回「Bucket Policy」頁面,複製您的 Bucket ARN(Amazon 資源名稱)。
data:image/s3,"s3://crabby-images/17cd8/17cd81921e430a1be99bb70bcd9ea05ec5eeba81" alt="copy the aws arn"
將 ARN 貼到策略產生器頁面的 ARN 欄位,並在 ARN 後新增「/*」。這可確保策略適用於 Bucket 中的所有物件。然後點擊「Add Statement」。
data:image/s3,"s3://crabby-images/17684/17684e2bf27c1e7a58b0c15a15a7c32191cc8a33" alt="complete the statement"
生成策略後,點擊「Generate Policy」。
data:image/s3,"s3://crabby-images/16128/16128236368796b5b93cfae7f836517197be26da" alt="click on generate policy"
複製 JSON 文件內容。
data:image/s3,"s3://crabby-images/92449/924499df20ec1b1009d40a5a04a73f1b7e6e8505" alt="copy the generated policy"
回到「Edit bucket policy(編輯存取策略)」頁面,將生成的策略貼上。
data:image/s3,"s3://crabby-images/d2968/d29686c04d34bdb49c68e140e90ca481d13fdbb8" alt="paste the generated policy"
儲存變更以將 S3 Bucket 設定為公開。
啟用 S3 靜態網站
首先,前往 Bucket 的「Properties(屬性)」標籤。
data:image/s3,"s3://crabby-images/a83fc/a83fcc4eb94fcde39f9ca90b6bc862e77d4e6d33" alt="go to properties"
接著向下滾動至頁面底部,在「Static website hosting(靜態網站託管)」部分,點擊「Edit」。
data:image/s3,"s3://crabby-images/f82fd/f82fd77e9d4612f4d2293b13948c0997405611be" alt="click on edit to enable static website"
在「靜態網站託管」中,點擊「Enable(啟用)」。
data:image/s3,"s3://crabby-images/5a29b/5a29b0f17c91ff5b635fb681dae134b7ae708d95" alt="click on enable"
點擊後,會出現更多選項。在「Hosting type(託管類型)」中選擇「Host a static website(託管靜態網站)」。
data:image/s3,"s3://crabby-images/fd844/fd844108585b46e70586e49c74318ddbe75a8f98" alt="select the permissions"
向下滾動並點擊「Save changes」。
再次查看「Static website hosting」部分,您將獲得一個 URL,用於存取 S3 Bucket 的靜態網站。
data:image/s3,"s3://crabby-images/55fe8/55fe814b67f2e908816ecaf4e6015c20cc916b22" alt="copy the url of static website"
如果您按照以上步驟操作,應能成功存取您的 S3 靜態網站。與普通的 S3 Bucket 不同,文件現在具有不同的 URL 後綴,且不需要使用「index.html」或直接連結到文件的方式存取。
data:image/s3,"s3://crabby-images/cf1b8/cf1b8ee6319c7300ad1c0da3687ccc4cab66baee" alt="browse the website"
結語
Amazon S3 簡化了靜態網站的託管,提供一個安全、可擴展且經濟實惠的平台。通過簡單幾步啟用公共存取及配置靜態網站託管,您可以輕鬆地讓內容上線,展現使用 AWS 託管網站的便利性與效率。
댓글