ハマログ

株式会社イーツー・インフォの社員ブログ

CloudFrontでオリジンがS3のときに、ルートURLでファイルリストが表示される

AWSでS3をオリジンにしてCloudFrontで静的サイトとして公開したときに、ファイルは正しく表示されましたが、ルートURLにアクセスした際にS3のファイルリストが表示されてしまいました。
S3をパブリックアクセスにしてルートURLにアクセスしたところ、index.htmlファイルを読み込む動作になりました。こちらは問題なさそうです。

仕様でした

に記載がありました。
ルートオブジェクトを定義しない場合の CloudFront の動作

Amazon S3 バケットのコンテンツのリスト – 以下のいずれかの条件が満たされる場合、CloudFront を使用してディストリビューションにアクセスするユーザーにオリジンのコンテンツが表示されます。

バケットが適切に構成されていない。

ディストリビューションに関連付けられているバケット、およびバケット内のオブジェクトに対する Amazon S3 アクセス許可で、すべてのユーザーにアクセスが付与されている。

エンドユーザーがオリジンのルート URL を使用してオリジンにアクセスしている。
今回は、同URLに記載のある、「デフォルトのルートオブジェクトを指定する方法」で対応しました。

CloudFront→ディストリビューション→一般→設定→編集

デフォルトルートオブジェクト – オプション ビューワーが特定のオブジェクトの代わりにルート URL (/) を要求したときに返されるオブジェクト (ファイル名)。 にindex.htmlと入力
S3のファイルリストが表示されなくなりました。
AmazonAmazon S3 アクセス許可AWSCDNCFCloudFrontindex.htmlS3webインフラウェブオブジェクトオプションキャッシュディストリビューションデフォルトのルートオブジェクトパブリックアクセスビューワーファイルリストルートURL表示静的サイト

  kaneko tomo   2023年11月10日


関連記事

AWS Lightsailで構築してみた。

AWSに始まってGCPと来て、今度は「軽いやつなんでLightsailで構築して…

AWSのELBのエンドポイントにネイキッドドメインを設定する方法

Aレコード。そう思っていた時期が私にもありました。 「ドメインの設定なんてAレコ…

CodeBuildでError: ENOSPC: System limit for number of file watchers reachedにハマった

厳密にはこのエラーを解決するために必要な、fs.inotify.max_user…


← 前の投稿

次の投稿 →