aboutsummaryrefslogtreecommitdiff
path: root/files/ja/web/http/status/index.md
blob: 51061a80b36bdf9d73628352f6906c55aca53f83 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
---
title: HTTP レスポンスステータスコード
slug: Web/HTTP/Status
tags:
  - HTTP
  - ランディング
  - 概要
  - リファレンス
  - ステータスコード
  - ウェブ
translation_of: Web/HTTP/Status
---
{{HTTPSidebar}}

HTTP のレスポンスステータスコードは、特定の [HTTP](/ja/docs/Web/HTTP) リクエストが正常に完了したどうかを示します。
レスポンスは 5 つのクラスに分類されています。

1. [情報レスポンス](#情報レスポンス) (`100``199`)
2. [成功レスポンス](#成功レスポンス) (`200``299`)
3. [リダイレクトメッセージ](#リダイレクトメッセージ) (`300``399`)
4. [クライアントエラーレスポンス](#クライアントエラーレスポンス) (`400``499`)
5. [サーバーエラーレスポンス](#サーバーエラーレスポンス) (`500``599`)

以下のステータスコードは [RFC 2616 の第 10 章](https://datatracker.ietf.org/doc/html/rfc2616#section-10)で定義されています。更新版の仕様書は [RFC 7231](https://datatracker.ietf.org/doc/html/rfc7231#section-6) にあります。

> **Note:** [この一覧](#情報レスポンス)にないレスポンスを受け取った場合、それは標準外のレスポンスであり、おそらくそのサーバーソフトウェアに固有のものです。

## 情報レスポンス

- {{HTTPStatus(100, "100 Continue")}}
  - : これは暫定レスポンスで、その時点までのすべてに問題がなく、クライアントはリクエストを継続してよい、またもしリクエストが完了している場合はレスポンスを無視してよいことを示します。
- {{HTTPStatus(101, "101 Switching Protocols")}}
  - : このコードはクライアントからの {{HTTPHeader("Upgrade")}} リクエストヘッダーのレスポンスとして送信され、サーバーはプロトコルを切り替えていることを示します。
- {{HTTPStatus(102, "102 Processing")}} ({{Glossary("WebDAV")}})
  - : このコードは、サーバーはリクエストを受け取って処理しているが、まだレスポンスを提供できないことを示します。
- {{HTTPStatus(103, "103 Early Hints")}}
  - : このステータスコードは主に {{HTTPHeader("Link")}} ヘッダーとともに使用され、サーバーがリソースを準備している間、ユーザーエージェントがリソースの[先読み](/ja/docs/Web/HTML/Link_types/preload)を開始できるようにするためのものです。

## 成功レスポンス

- {{HTTPStatus(200, "200 OK")}}

  - : リクエストが成功したことを示します。成功が意味することは、 HTTP メソッドにより異なります。

    - `GET`: リソースが読み込まれ、メッセージ本文で転送された。
    - `HEAD`: メッセージ本文がなく、表現ヘッダーがレスポンスに含まれている。
    - `PUT` または `POST`: 操作の結果を表すリソースがメッセージ本文で送信される。
    - `TRACE`: メッセージ本文に、サーバーが受け取ったリクエストメッセージが含まれている。

- {{HTTPStatus(201, "201 Created")}}
  - : リクエストは成功し、その結果新たなリソースが作成されたことを示します。これは一般的に、 `POST` リクエストや、一部の `PUT` リクエストを送信した後のレスポンスになります。
- {{HTTPStatus(202, "202 Accepted")}}
  - : リクエストは受理されたが、まだ実行されていないことを示します。
    これはあいまいです。 HTTP ではリクエストを処理した結果を示す非同期なレスポンスを後から送信する方法がないためです。
    リクエストは別のプロセスかサーバーが処理する、またはバッチ処理する予定です。
- {{HTTPStatus(203, "203 Non-Authoritative Information")}}
  - : このレスポンスコードは、返されるメタ情報のセットが生成元のサーバーから得られるセットと同一ではなく、ローカルまたは第三者の持つ複製から収集したことを表します。
    これは主に、他のリソースのミラーやバックアップを使用したときに使用されます。
    このような場合以外は、このステータスより `200 OK` のほうが好ましいレスポンスです。
- {{HTTPStatus(204, "204 No Content")}}
  - : リクエストに対して送信するコンテンツはありませんが、ヘッダーは有用であることを示します。ユーザーエージェントはこのリソースに関するキャッシュ済みのヘッダーを、新たな内容に更新します。
- {{HTTPStatus(205, "205 Reset Content")}}
  - : ユーザーエージェントに対し、リクエストを送信した文書をリセットするよう伝達します。
- {{HTTPStatus(206, "206 Partial Content")}}
  - : このレスポンスコードは、クライアントが {{HTTPHeader("Range")}} ヘッダーを送信し、リソースの一部だけをリクエストした時に使用されます。
- {{HTTPStatus(207, "207 Multi-Status")}} ({{Glossary("WebDAV")}})
  - : 複数のステータスコードがあてはまる状況で、複数のリソースに関する情報を伝えます。
- {{HTTPStatus(208, "208 Already Reported")}} ({{Glossary("WebDAV")}})
  - : 同じコレクションに繰り返し複数のバインディングする内部メンバーを列挙することを避けるため、 `<dav:propstat>` レスポンス要素の内部で使用します。
- {{HTTPStatus(226, "226 IM Used")}} ([HTTP Delta encoding](https://datatracker.ietf.org/doc/html/rfc3229))
  - : サーバーはリソースへの `GET` リクエストの処理を完了しており、レスポンスは現在のインスタンスに適用された 1 つ以上の instance manipulation の結果を表します。

## リダイレクトメッセージ

- {{HTTPStatus(300, "300 Multiple Choice")}}
  - : リクエストに対して複数のレスポンスがあることを示します。ユーザーエージェントやユーザーは、それらからひとつを選択します。 (複数のレスポンスからひとつを選ぶ方法は標準化されていませんが、選択肢へリンクする HTML が推奨されており、それによってユーザーが選択することができます。)
- {{HTTPStatus(301, "301 Moved Permanently")}}
  - : リクエストされたリソースの URL が永遠に変更されたことを示します。レスポンスで新しい URL が与えられます。
- {{HTTPStatus(302, "302 Found")}}
  - : このレスポンスコードは、リクエストされたリソースの URI が _一時的に_ 変更されたことを示します。
    URI は将来、さらに変更される可能性があります。従って、クライアントは将来のリクエストでも同じ URI を使用するべきです。
- {{HTTPStatus(303, "303 See Other")}}
  - : サーバーはこのレスポンスを、リクエストされたリソースを別の URI で GET リクエストを使用して取得するようクライアントを誘導するために送信します。
- {{HTTPStatus(304, "304 Not Modified")}}
  - : これはキャッシュ用に使用します。
    このレスポンスコードはクライアントに対して、レスポンスは変更されていないことを示します。よって、クライアントはキャッシュ済みのレスポンスを使い続けます。
- `305 Use Proxy` {{deprecated_inline}}
  - : これは旧バージョンの HTTP 仕様書で、リクエストされたレスポンスはプロキシーからアクセスしなければならないことを示していました。
    プロキシーのインバンド設定に関するセキュリティの懸念により、このレスポンスコードは非推奨になりました。
- `306 unused`
  - : このレスポンスコードはもう使用されず、予約済みです。 HTTP/1.1 仕様書の旧バージョンでは使用されていました。
- {{HTTPStatus(307, "307 Temporary Redirect")}}
  - : サーバーはこのレスポンスを、リクエストされたリソースを別の URI で、元のリクエストと同じメソッドを使用して取得するようクライアントを誘導するために送信します。
    これは `302 Found` HTTP レスポンスコードと同じ意味を持ちますが、ユーザーエージェントは使用する HTTP メソッドを*変更してはならない*点が異なります。始めのリクエストで `POST` を用いた場合は、次のリクエストでも `POST` を使用しなければなりません。
- {{HTTPStatus(308, "308 Permanent Redirect")}}
  - : これは、リソースが HTTP の `Location:` レスポンスヘッダーで指定した別の URI へ永続的に置かれていることを示します。
  これは `301 Moved Permanently` HTTP レスポンスコードと同じ意味を持ちますが、ユーザーエージェントは使用する HTTP メソッドを*変更してはならない*点が異なります。始めのリクエストで `POST` を用いた場合は、次のリクエストでも `POST` を使用しなければなりません。

## クライアントエラーレスポンス

- {{HTTPStatus(400, "400 Bad Request")}}
  - : 構文が無効であるためサーバーがリクエストを理解できないことを示します。
- {{HTTPStatus(401, "401 Unauthorized")}}
  - : HTTP 標準では "unauthorized" (不許可) と定義されていますが、意味的にはこのレスポンスは "unauthenticated" (未認証) です。
    つまり、クライアントはリクエストされたレスポンスを得るためには認証を受けなければなりません。
- {{HTTPStatus(402, "402 Payment Required")}} {{experimental_inline}}
  - : このレスポンスコードは、将来のために予約されています。このコードは当初、デジタル決済システムで使用するために作成されましたが、ごく稀にしか使用されておらず、標準的な慣例はありません。
- {{HTTPStatus(403, "403 Forbidden")}}
  - : 認証されていないなどの理由でクライアントにコンテンツのアクセス権がなく、サーバーが適切なレスポンスの返信を拒否していることを示します。
    `401 Unauthorized` とは異なり、クライアントの ID がサーバーに知られています。
- {{HTTPStatus(404, "404 Not Found")}}
  - : サーバーがリクエストされたリソースを発見できないことを示します。
    ブラウザーでは、これは URL が解釈できなかったことを意味します。
    API では、これは通信先が有効であるものの、リソース自体が存在しないことを意味することがあります。
    サーバーは認証されていないクライアントからリソースの存在を隠すために、 403 の代わりにこのレスポンスを返すことがあります。
    このレスポンスコードはウェブで頻繁に見られるため、おそらくもっとも有名なコードでしょう。
- {{HTTPStatus(405, "405 Method Not Allowed")}}
  - : サーバーがリクエストメソッドを理解しているものの、無効にされており使用することができません。例えば、 API がリソースを DELETE することを禁止できます。 `GET` および `HEAD` の 2 つは必須で、無効にすることができず、このエラーコードを返してはいけません。
- {{HTTPStatus(406, "406 Not Acceptable")}}
  - : このレスポンスは、ウェブサーバーが [サーバー駆動型コンテンツネゴシエーション](/ja/docs/HTTP/Content_negotiation#server-driven_negotiation) を行った結果、ユーザーエージェントから与えられた条件に合うコンテンツが見つからない場合に送信されます。
- {{HTTPStatus(407, "407 Proxy Authentication Required")}}
  - : これは `401 Unauthorized` と似ていますが、プロキシーサーバーが認証を要求している点が異なります。
- {{HTTPStatus(408, "408 Request Timeout")}}
  - : このレスポンスはクライアントが以前にリクエストを行っていない、アイドル状態の接続において一部のサーバーが送信します。
    サーバーが使用していない接続の終了を望んでいることを示します。
    このレスポンスは Chrome、 Firefox 27 以降、IE9 など、閲覧を高速化するための HTTP 事前接続機能を使用する一部のブラウザーでよく使用します。
    また、一部のサーバーはこのメッセージを送らずに接続を閉じることに注意してください。
- {{HTTPStatus(409, "409 Conflict")}}
  - : このレスポンスは、リクエストがサーバーの現在の状態と矛盾する場合に送られるでしょう。
- {{HTTPStatus(410, "410 Gone")}}
  - : このレスポンスは、リクエストされたコンテンツがサーバーから永久に削除され、転送先アドレスがない場合に送られます。
    クライアントはこのリソースへのキャッシュやリンクを削除することが期待されます。
    HTTP 仕様書ではこのコードを「期間限定のプロモーションサービス」に使用することを意図しています。
    API はこのステータスコードの場合、削除されたリソースを無理に示そうとするべきではありません。
- {{HTTPStatus(411, "411 Length Required")}}
  - : サーバーが `Content-Length` ヘッダーフィールドを要求しているが、リクエストで定義されていないために、サーバーがリクエストを拒否したことを示します。
- {{HTTPStatus(412, "412 Precondition Failed")}}
  - : サーバー側で適合しない前提条件が、クライアント側のヘッダーに含まれていることを示します。
- {{HTTPStatus(413, "413 Payload Too Large")}}
  - : リクエストの本体がサーバーで定めている上限を超えていることを示します。
    サーバーは接続を閉じるか、`Retry-After` ヘッダーフィールドを返します。
- {{HTTPStatus(414, "414 URI Too Long")}}
  - : クライアントがリクエストした URI が、サーバーで扱える長さを超えていることを示します。
- {{HTTPStatus(415, "415 Unsupported Media Type")}}
  - : リクエストされたデータのメディア形式をサーバーが対応しておらず、サーバーはリクエストを拒否したことを示します。
- {{HTTPStatus(416, "416 Range Not Satisfiable")}}
  - : リクエスト内の `Range` ヘッダーフィールドで指定された範囲を満たすことができないことを示します。
    指定した範囲が、目的の URI のデータサイズを超えている可能性があります。
- {{HTTPStatus(417, "417 Expectation Failed")}}
  - : このレスポンスコードは、`Expect` リクエストヘッダーで指定された内容がサーバー側と適合しないことを示します。
- {{HTTPStatus(418, "418 I'm a teapot")}}
  - : サーバーは、ティーポットでコーヒーを淹れようとする試みを拒否します。
- {{HTTPStatus(421, "421 Misdirected Request")}}
  - : リクエストは、レスポンスを生成できないサーバーに送られました。
    リクエストの URI に含まれているスキームや権限の組み合わせに対してレスポンスを生成するよう設定されていないサーバーが、このコードを送ることがあります。
- {{HTTPStatus(422, "422 Unprocessable Entity")}} ({{Glossary("WebDAV")}})
  - : リクエストは適正ですが、意味が誤っているために従うことができません。
- {{HTTPStatus(423, "423 Locked")}} ({{Glossary("WebDAV")}})
  - : アクセス中のリソースはロックされています。
- {{HTTPStatus(424, "424 Failed Dependency")}} ({{Glossary("WebDAV")}})
  - : 前のリクエストが失敗したため、このリクエストも失敗しました。
- {{HTTPStatus(425, "425 Too Early")}} {{experimental_inline}}
  - : サーバーが、繰り返される可能性のあるリクエストを処理するリスクを望まないことを示します。
- {{HTTPStatus(426, "426 Upgrade Required")}}
  - : サーバーは現在のプロトコルを使用したリクエストの実行を拒否しましたが、クライアントが別のプロトコルにアップグレードした後は受け入れることができます。
    サーバーは必要なプロトコルを示すために、426 のレスポンスで {{HTTPHeader("Upgrade")}} ヘッダーフィールドを送信しなければなりません。
- {{HTTPStatus(428, "428 Precondition Required")}}
  - : オリジンサーバーはリクエストが条件付きになることを必要としています。
    このレスポンスは「ロストアップデート問題」 (クライアントがリソースの状態を取得して変更およびサーバーに送信している間に、第三者がサーバーの状態を変更して競合が発生すること) を防ごうとするものです。
- {{HTTPStatus(429, "429 Too Many Requests")}}
  - : ユーザーは一定の時間内に大量のリクエストを送信しました ("レート制限")。
- {{HTTPStatus(431, "431 Request Header Fields Too Large")}}
  - : ヘッダーフィールドが大きすぎるため、サーバーはリクエストの処理を望みません。
    ヘッダーフィールドのサイズを削減した後に、リクエストを再送信できます。
- {{HTTPStatus(451, "451 Unavailable For Legal Reasons")}}
  - : ユーザーエージェントが政府によって検閲されたウェブページなど、違法なリソースをリクエストしています。

## サーバーエラーレスポンス

- {{HTTPStatus(500, "500 Internal Server Error")}}
  - : サーバー側で処理方法がわからない事態が発生したことを示します。
- {{HTTPStatus(501, "501 Not Implemented")}}
  - : リクエストメソッドをサーバーが対応しておらず、扱えないことを示します。サーバーが対応しなければならない (従って、このコードを返してはならない) メソッドは `GET``HEAD` だけです。
- {{HTTPStatus(502, "502 Bad Gateway")}}
  - : このエラーレスポンスは、リクエストの処理に必要なレスポンスを受け取るゲートウェイとして動作するサーバーが無効なレスポンスを受け取ったことを示します。
- {{HTTPStatus(503, "503 Service Unavailable")}}
  - : サーバーはリクエストを処理する準備ができていないことを示します。
    一般的な原因は、サーバーがメンテナンスや過負荷でダウンしていることです。
    このレスポンスとともに問題について説明する、ユーザーにわかりやすいページを送信するべきであることに注意してください。
    このレスポンスは一時的な状況について使用するものであり、また可能であれば、サービスが復旧する前に HTTP の `Retry-After` ヘッダーに予定時刻を含めてください。
    また、これら一時的な状況のレスポンスは通常キャッシュされるべきではないことから、ウェブ管理者はこのレスポンスとともに送られるキャッシュ関連のヘッダーに注意しなければなりません。
- {{HTTPStatus(504, "504 Gateway Timeout")}}
  - : このエラーレスポンスは、ゲートウェイとして動作するサーバーが時間内にレスポンスを得られない場合に送られます。
- {{HTTPStatus(505, "505 HTTP Version Not Supported")}}
  - : リクエストで使用した HTTP のバージョンにサーバーが対応していないことを示します。
- {{HTTPStatus(506, "506 Variant Also Negotiates")}}
  - : サーバーに内部構成エラーがあることを示します。選択したバリアントリソースが透過的コンテンツネゴシエーション自体に携わるよう設定されており、ネゴシエーションプロセスが正しく終了しなかったことを示します。
- {{HTTPStatus(507, "507 Insufficient Storage")}} ({{Glossary("WebDAV")}})
  - : サーバーがリクエストを完了させるのに必要な表現を保存することができなかったため、メソッドがリソースに対して実行できなかったことを示します。
- {{HTTPStatus(508, "508 Loop Detected")}} ({{Glossary("WebDAV")}})
  - : サーバーは、リクエストの処理中に無限ループを検出しました。
- {{HTTPStatus(510, "510 Not Extended")}}
  - : サーバーがリクエストを処理するために、リクエストをさらに拡張することが必要です。
- {{HTTPStatus(511, "511 Network Authentication Required")}}
  - : クライアントがネットワークでアクセスするために認証が必要であることを示します。

## ブラウザーの互換性

{{Compat("http.status")}}

## 関連情報

- [Wikipedia の、HTTP ステータスコードの一覧](https://en.wikipedia.org/wiki/List_of_HTTP_status_codes)
- [HTTP ステータスコードの、IANA 公式レジストリー](https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml)