この記事では、Firebase を使っているときに表示される 403 というエラーの意味と、その直し方を順を追って説明します。
Firebase の 403 とは何か?(公式の定義)
403 は、HTTP標準仕様(RFC 9110)で定められているステータスコードの一つです。
Firebase の文脈では、このコードは次のことを意味します。
Firebaseのセキュリティルールによってアクセスが拒否された。
このエラーが出たときは、慌てずに次の「原因」の節を確認してください。 多くの場合、設定の見直しや手順の確認だけで解決できます。
このエラーが発生する主な原因(起きる理由の整理)
Firebase で 403 が出るときに、最もよく見られる原因を挙げます。 自分の状況に当てはまるものを探してみてください。
- Firestoreまたは Cloud StorageのセキュリティルールがWriteやReadを許可していない
- ログインしていない状態でログイン必須のデータにアクセスしている
- 別のユーザーが所有するデータに対して書き込みを試みている
具体的な解決手順とチェックリスト(順番どおりに試す)
上の原因ごとの対処法を、実行できる手順の形でまとめました。 上から順番に試すことで、多くの場合は解決に近づけます。
- Firebaseコンソールの「Rules Playground」でルールのシミュレーションを実行して拒否理由を確認する
- セキュリティルールで request.auth != null の条件を正しく設定する
- ルールの条件式にデバッグ用の debug()関数を追加してログを確認する
まとめ
Firebase の 403 エラーは、上記のいずれかの原因によって発生するケースがほとんどです。 チェックリストを一つずつ確認することで、大半の問題は自力で解決できます。
それでも解決しない場合は、次の方法を試してください。
- Firebase の公式ドキュメントで最新の情報を確認する
- エラーメッセージの全文をコピーして検索エンジンで調べる
- 公式のコミュニティフォーラムやサポートに問い合わせる
免責事項:本記事の内容は、執筆時点の公開情報をもとに作成したものです。ソフトウェアの仕様やAPIの動作は予告なく変更されることがあります。最新かつ正確な情報については、各ツールの公式ドキュメントを必ずご確認ください。本記事の情報を利用した結果生じたいかなる損害についても、著者および運営者は責任を負いかねます。