ハマログ

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

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日


関連記事

Amazon Linux 2のExtras LibraryでインストールしたPHP7.2をPHP7.4に変更する

しばらくほったらかしだったので少し前にAmazon Linux 2にExtras…

Route 53 ゾーンファイルをインポート

AWS Route 53 のゾーンファイルをインポートする機能でエラーが発生した…

Amazon Linux2でEBSボリュームを拡張する

EC2で運用中の本番サーバーのEBSディスク容量が標準の8GBになっていたので、…


← 前の投稿

次の投稿 →