0
2

【AWS】S3+CloudFrontのOACでセキュアに静的ウェブサイトを公開する方法

Last updated at Posted at 2024-08-05

初めに

この記事では、AWSのAmazon S3とCloudFrontのオリジンアクセスコントロール (OAC) を活用して、HTTPS通信でセキュリティを強化しつつ静的ウェブサイトを公開する方法を説明します。

S3で静的ファイルをホスティングする際のリスク

Amazon S3で静的ホスティングする際によくある構成として、S3バケットのブロックパブリックアクセス設定を無効にしてコンテンツにパブリックアクセスさせるというのがあると思います。
image.png

しかし、パブリックアクセスの許可にはいくつかリスクがあります。
主には以下です(1)
データ漏洩のリスク:
パブリックアクセスが許可されているバケットやオブジェクトは、インターネット上の誰でもアクセス可能になるため、機密情報が漏洩するリスクが高まります。

不正アクセスのリスク:
パブリックアクセスを許可することで、不正アクセスや悪意のある攻撃のターゲットとなりやすくなります。

対策

上記の対策としてはAmazon S3バケットをオリジンとして使用し、CloudFrontを介してコンテンツを配信することができます。セキュリティを確保するために、オリジンアクセスコントロール (OAC) を使用して、CloudFrontディストリビューションのみがS3バケットにアクセスできるように設定します(2)

この構成の利点は、ブロックパブリックアクセス設定を有効にしたまま配信出来ることと、エンドユーザーのリクエストがHTTPSを使用するように強制出来ることです。

以下今回のソリューションのアーキテクチャ図です。

セキュアな静的ホスティング構成図.drawio.png

実装手順

HTMLファイルの準備

まず前提として、今回ホスティングさせる静的ファイルを用意してください。
特にない場合は、以下URLから私のGithubページにあるHTMLファイルをダウンロードできます。
https://github.com/Sorao-high/-Capybara-homepage

1.jpg

S3バケットの設定

1). S3バケットを作成します。AWSマネジメントコンソールにログインし、S3を開きます。
「バケットを作成」を押します。
2.JPG

2). バケットタイプは「汎用」を選択し、バケット名を入力します。あとはデフォルトの値のまま「バケットを作成」を押します。

この時、バケット名はグローバルに一意である必要があります。他のAWSアカウントが既に使用しているバケット名は使用できません。あと大文字も使用できないので気を付けましょう(3)。バケット名の詳細な命名規則は参考文献を参照ください。

3.JPG
4.JPG

5 - コピー.JPG

コンテンツのアップロード

1). 作成したバケットの「アップロード」を押します。
7.JPG

2). ホスティングさせるファイルをアップロードします。
私のGithubからダウンロードした方は「AWStest.html」と「AWStest.png」をアップロードしてください。このとき「-Capybara-homepage-main」ファイルや「AWStest」ごとまとめてアップロードすると、後述の作業とパスが変わる可能性があるので、「AWStest.html」と「AWStest.png」をひとつずつアップロードしてください。
9.JPG

CloudFrontの設定

1). CloudFrontを開き、「CloudFront ディストリビューションを作成」を押します。
2.JPG

2). 以下項目を入力し、「ディストリビューションを作成」。
Origin Domain:先ほど作成したS3バケットを選択
名前:オリジンの名前
オリジンアクセス:「Origin access control settings(recommended)」を選択
Origin access control:「Creat new OAC」を押下
ウェブアプリケーションファイアウォール(WAF):「セキュリティを有効にしないでください」を選択

3.JPG
7.JPG
8.JPG

3). CloudFrontからS3へのアクセスを許可するための作業です。
「ポリシーをコピー」を押し、念のためにメモなどにペーストしておいてください。
「S3バケットの権限に移動してポリシーを更新する」を押してください。S3に遷移します。
9.JPG

4). S3に遷移したら、「アクセス許可」を押します。
11.JPG

5). 下へスクロールしていくとバケットポリシーの項目があるので、「編集」を押します。
12.JPG

6). 赤枠に、先ほどコピーしたポリシーを貼り付けます。
13.JPG

「変更の保存」を押します。
15.JPG

7). CloudFrontページに戻り、作成したディストリビューションを選択し詳細設定の「一般」から「最終更新日」に日時が表示されているかと、「ディストリビューションドメイン名」を確認し、作業は完了となります。

ディストリビューションドメイン名はこのあとコンテンツへのアクセスの時に必要になりますのでコピーなどしてください。

17.JPG

結果確認

ちゃんとアクセスできるか確認します。
CloudFrontからコンテンツにアクセスするには、ディストリビューションドメイン名とアクセスさせたいコンテンツファイルのバケット内パスを組み合わせ、ディストリビューションドメイン名/コンテンツパスのようなURLを使用します(4)

今回手順通り私のHTMLファイルを使用していれば、以下のURLになります。「ディストリビューションドメイン名」を自身のものに書き換えてください。

https://ディストリビューションドメイン名/AWStest.html

問題なければこのような画面が表示されるはずです。
1.JPG

削除手順

このまま運用する予定がない方は必要以上に料金が発生しないようにリソースを削除します。
アーキテクトの構造上まずディストリビューションの削除をして、その次にS3バケットを削除する順番となります。

ディストリビューションの削除

1). CloudFrontを開いて作成したディストリビューションを選択し、「無効」を押します。
1.JPG

2). 「無効」を押します。
2.JPG

3). 最終変更日が「デプロイ」から具体的な日時に更新されるまで待ちます。数分かかる場合があります。
3.JPG
日時が更新されたら「削除」を押します。
5.JPG

4). 「削除」を押し、ディストリビューションが消えてることを確認して完了です。
6.JPG
7.JPG

S3バケットの削除

1). S3を開き作成したバケットを選択し「空にする」を押します。
1.JPG

2). バケット~削除しますか?に「完全に削除」と入力し、「空にする」を押します。
2.JPG

3). もう一度バケットを選択し、「削除」を押します。
バケット~削除しますか?にバケット名を入力し、「バケットを削除」を押します。
4.JPG

4). 削除されたことを確認して削除作業完了です。
5.JPG

終わりに

この記事ではAWSのS3とCloudFrontを使用して、セキュリティを重視しつつ静的ウェブサイトを公開する方法についてご紹介しました。パブリックアクセスのリスクを避けつつ、アクセスコントロールをきちんと設定することで、セキュアなウェブサイト運営をすることができます。

この記事が参考になりましたらぜひ「いいね」「フォロー」など励みになるのでよろしくお願いします!

参考文献

  1. Amazon S3 ストレージへのパブリックアクセスのブロック
  2. 安全な静的ウェブサイトの開始方法.
  3. バケットの名前付け.
  4. ステップ 4: CloudFront からコンテンツにアクセスする.
0
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
2