HTTP/Statuscode: Unterschied zwischen den Versionen

Aus Foxwiki
Keine Bearbeitungszusammenfassung
 
(15 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
'''topic''' - Kurzbeschreibung
'''HTTP-Statuscode''' - Rückmeldungen eines Webservers


== Beschreibung ==
== Beschreibung ==
[[File:2024-02-29_13-00-00_UTC.jpg|mini|400px]]
[[Datei:HTTP 404.png|mini|Beispiel einer Webseite, die von einem Webserver zusätzlich zum 404 Statuscode gesendet wurde.]]
Jede HTTP-Anfrage wird vom Server mit einem HTTP-Statuscode beantwortet
; Jede HTTP-Anfrage wird vom Server mit einem HTTP-Statuscode beantwortet
* ob die Anfrage erfolgreich bearbeitet wurde
* ob die Anfrage erfolgreich bearbeitet wurde
* teilt dem Client/Browser im Fehlerfall mit, wo (zum Beispiel Umleitung) beziehungsweise wie (zum Beispiel mit Authentifizierung) er die gewünschten Informationen (wenn möglich) erhalten kann
* teilt dem Client/Browser im Fehlerfall mit, wo (etwa Umleitung) oder wie (zum Beispiel mit Authentifizierung) er die gewünschten Informationen (wenn möglich) erhalten kann


Ein '''HTTP-Statuscode''' wird von einem [[Server]] auf jede [[Hypertext Transfer Protocol|HTTP]]-Anfrage als Antwort geliefert. Auf der anfragenden Seite steht dabei ein [[Client]] wie beispielsweise ein [[Webbrowser]]. Der Server teilt durch den HTTP-Statuscode dem Client mit, ob die Anfrage erfolgreich bearbeitet wurde. Im Fehlerfall gibt der Statuscode Auskunft darüber, wo (beispielsweise über eine Umleitung) oder wie (zum Beispiel mit [[HTTP-Authentifizierung|Authentifizierung]]) er die gewünschten Informationen erhalten kann. Am bekanntesten sind dabei die Codes 404: „Nicht gefunden“, 403: „Fehlende Zugriffsberechtigung“ und 400: „Fehlerhafte Anfrage“
; HTTP-Statuscode
[[Datei:HTTP 404.png|mini|Beispiel einer Webseite, die von einem Webserver zusätzlich zum 404 Statuscode gesendet wurde.]]
[[File:2024-02-29_13-00-00_UTC.jpg|mini|300px|https://www.instagram.com/p/C37qsaiAHTn/]]
Ein '''HTTP-Statuscode''' wird von einem [[Server]] auf jede [[Hypertext Transfer Protocol|HTTP]]-Anfrage als Antwort geliefert.  
* Auf der anfragenden Seite steht dabei ein Client wie ein Webbrowser.
* Der Server teilt durch den HTTP-Statuscode dem Client mit, ob die Anfrage erfolgreich bearbeitet wurde.
* Im Fehlerfall gibt der Statuscode Auskunft darüber, wo (beispielsweise über eine Umleitung) oder wie (zum Beispiel mit [[HTTP-Authentifizierung|Authentifizierung]]) er die gewünschten Informationen erhalten kann.  
 
; <nowiki>404: „Nicht gefunden“</nowiki>
* Am bekanntesten sind dabei die Codes 404: „Nicht gefunden“, 403: „Fehlende Zugriffsberechtigung“ und 400: „Fehlerhafte Anfrage“


Die erste Ziffer eines Statuscodes stellt die Statusklasse dar. Sie sind in RFC 7231 (ersetzt RFC 2616), sowie RFC 2518, RFC 2817, RFC 2295, RFC 2774 und RFC 4918 spezifiziert. Einige gehören zum [[WebDAV|Distributed Authoring (WebDAV)]]
; Statusklassen
Die erste Ziffer eines Statuscodes stellt die Statusklasse dar.  
* Sie sind in RFC 7231 (ersetzt RFC 2616), sowie RFC 2518, RFC 2817, RFC 2295, RFC 2774 und RFC 4918 spezifiziert.  
* Einige gehören zum [[WebDAV|Distributed Authoring (WebDAV)]]


Neben den in [[Request for Comments|RFC]] standardisierten Statuscodes verwenden manche Softwarehersteller auch [[proprietär]]e Codes für eigens definierte Status- und Fehlermeldungen. Andere Software kann dem Benutzer diese Codes nur als allgemeinen unbekannten Fehler anzeigen; nicht aber eine Übersetzung und Hinweise zum weiteren Vorgehen. Teilweise können die Server den Begleitumständen der Anfrage bereits entnehmen, dass es sich um die zugehörige Spezialsoftware handelt, und geben nur dann die proprietären Codes zurück. In diesem Artikel sind einige proprietäre Codes aufgeführt und entsprechend gekennzeichnet
Neben den in [[Request for Comments|RFC]] standardisierten Statuscodes verwenden manche Softwarehersteller auch [[proprietär]]e Codes für eigens definierte Status- und Fehlermeldungen.  
* Andere Software kann dem Benutzer diese Codes nur als allgemeinen unbekannten Fehler anzeigen; nicht aber eine Übersetzung und Hinweise zum weiteren Vorgehen.  
* Teilweise können die Server den Begleitumständen der Anfrage bereits entnehmen, dass es sich um die zugehörige Spezialsoftware handelt, und geben nur dann die proprietären Codes zurück.  
* In diesem Artikel sind einige proprietäre Codes aufgeführt und entsprechend gekennzeichnet


{| class="wikitable options big"
{| class="wikitable options big"
Zeile 49: Zeile 62:


== HTTP-Statuscodes ==
== HTTP-Statuscodes ==
[[File:httpStatusCodes.jpg|mini|400px]]
=== 1xx – Informationen ===
=== 1xx – Informationen ===
Die Bearbeitung der Anfrage dauert noch an
Die Bearbeitung der Anfrage dauert noch an
Zeile 59: Zeile 73:
|-
|-
! 100
! 100
| {{lang|en|''Continue''}}
| Continue
| Die laufende Anfrage an den Server wurde noch nicht zurückgewiesen. (Wird im Zusammenhang mit dem „Expect 100-continue“-Header-Feld verwendet.) Der Client kann nun mit der potentiell sehr großen Anfrage fortfahren
| Die laufende Anfrage an den Server wurde noch nicht zurückgewiesen. (Wird im Zusammenhang mit dem „Expect 100-continue“-Header-Feld verwendet.) Der Client kann nun mit der potentiell sehr großen Anfrage fortfahren
|-
|-
! 101
! 101
| {{lang|en|''Switching Protocols''}}
| Switching Protocols
| Wird verwendet, wenn der Server eine Anfrage mit gesetztem „Upgrade“-Header-Feld empfangen hat und mit dem Wechsel zu einem anderen Protokoll einverstanden ist. Anwendung findet dieser Status-Code beispielsweise im Wechsel von HTTP zu [[WebSocket]]
| Wird verwendet, wenn der Server eine Anfrage mit gesetztem „Upgrade“-Header-Feld empfangen hat und mit dem Wechsel zu einem anderen Protokoll einverstanden ist.  
* Anwendung findet dieser Status-Code beispielsweise im Wechsel von HTTP zu [[WebSocket]]
|-
|-
! 102
! 102
| {{lang|en|''Processing''}}
| Processing
| Wird verwendet, um ein Timeout zu vermeiden, während der Server eine zeitintensive Anfrage bearbeitet. Dies ist eine Interim-Antwort, auf die auf derselben Verbindung ohne weitere Client-Anfrage eine endgültige Antwort folgen muss
| Wird verwendet, um ein Timeout zu vermeiden, während der Server eine zeitintensive Anfrage bearbeitet.  
* Dies ist eine Interim-Antwort, auf die auf derselben Verbindung ohne weitere Client-Anfrage eine endgültige Antwort folgen muss
|-
|-
! 103
! 103
| {{lang|en|''Early Hints''}}
| Early Hints
| Wird zusammen mit dem „Link“ Header verwendet, um das Vorladen von Ressourcen zu ermöglichen, während der Server die finale Antwort noch vorbereitet
| Wird zusammen mit dem „Link“ Header verwendet, um das Vorladen von Ressourcen zu ermöglichen, während der Server die finale Antwort noch vorbereitet
|}
|}
Zeile 85: Zeile 101:
|-
|-
! 200
! 200
| {{lang|en|''OK''}}
| OK
| Die Anfrage wurde erfolgreich bearbeitet und das Ergebnis der Anfrage wird in der Antwort übertragen
| Die Anfrage wurde erfolgreich bearbeitet und das Ergebnis der Anfrage wird in der Antwort übertragen
|-
|-
! 201
! 201
| {{lang|en|''Created''}}
| Created
| Die Anfrage wurde erfolgreich bearbeitet. Die angeforderte Ressource wurde vor dem Senden der Antwort erstellt. Das „Location“-Header-Feld enthält eventuell die Adresse der erstellten Ressource
| Die Anfrage wurde erfolgreich bearbeitet.  
* Die angeforderte Ressource wurde vor dem Senden der Antwort erstellt.  
* Das „Location“-Header-Feld enthält eventuell die Adresse der erstellten Ressource
|-
|-
! 202
! 202
| {{lang|en|''Accepted''}}
| Accepted
| Die Anfrage wurde akzeptiert, wird aber zu einem späteren Zeitpunkt ausgeführt. Das Gelingen der Anfrage kann nicht garantiert werden
| Die Anfrage wurde akzeptiert, wird aber zu einem späteren Zeitpunkt ausgeführt.  
* Das Gelingen der Anfrage kann nicht garantiert werden
|-
|-
! 203
! 203
| {{lang|en|''Non-Authoritative Information''}}
| Non-Authoritative Information
| Der Server agiert als „Transforming [[Proxy-Server|Proxy]]“, erhielt eine ''200 OK'' Antwort von der Quelle und antwortet mit einem veränderten Dokument der Quelle
| Der Server agiert als „Transforming [[Proxy-Server|Proxy]]“, erhielt eine ''200 OK'' Antwort von der Quelle und antwortet mit einem veränderten Dokument der Quelle
|-
|-
! 204
! 204
| {{lang|en|''No Content''}}
| No Content
| Die Anfrage wurde erfolgreich durchgeführt, die Antwort enthält jedoch bewusst keine Daten
| Die Anfrage wurde erfolgreich durchgeführt, die Antwort enthält jedoch bewusst keine Daten
|-
|-
! 205
! 205
| {{lang|en|''Reset Content''}}
| Reset Content
| Die Anfrage wurde erfolgreich durchgeführt; der Client soll das Dokument neu aufbauen und Formulareingaben zurücksetzen
| Die Anfrage wurde erfolgreich durchgeführt; der Client soll das Dokument neu aufbauen und Formulareingaben zurücksetzen
|-
|-
! 206
! 206
| {{lang|en|''Partial Content''}}
| Partial Content
| Der angeforderte Teil wurde erfolgreich übertragen (wird im Zusammenhang mit einem „Content-Range“-Header-Feld oder dem Content-Type multipart/byteranges verwendet). Kann einen Client über Teil-Downloads informieren (wird zum Beispiel von [[Wget]] genutzt, um den Downloadfortschritt zu überwachen oder einen Download in mehrere Streams aufzuteilen)
| Der angeforderte Teil wurde erfolgreich übertragen (wird im Zusammenhang mit einem „Content-Range“-Header-Feld oder dem Content-Type multipart/byteranges verwendet).  
* Kann einen Client über Teil-Downloads informieren (wird zum Beispiel von [[Wget]] genutzt, um den Downloadfortschritt zu überwachen oder einen Download in mehrere Streams aufzuteilen)
|-
|-
! 207
! 207
| {{lang|en|''Multi-Status''}}
| Multi-Status
| WebDAV RFC 4918 – Die Antwort enthält ein in WebDAV spezifiziertes XML-Dokument, das mehrere Statuscodes zu unabhängig voneinander durchgeführten Operationen enthält
| WebDAV RFC 4918 – Die Antwort enthält ein in WebDAV spezifiziertes XML-Dokument, das mehrere Statuscodes zu unabhängig voneinander durchgeführten Operationen enthält
|-
|-
! 208
! 208
| {{lang|en|''Already Reported''}}
| Already Reported
| WebDAV RFC 5842 – Die Mitglieder einer WebDAV-Bindung wurden bereits zuvor aufgezählt und sind in dieser Anfrage nicht mehr vorhanden
| WebDAV RFC 5842 – Die Mitglieder einer WebDAV-Bindung wurden bereits zuvor aufgezählt und sind in dieser Anfrage nicht mehr vorhanden
|-
|-
! 226
! 226
| {{lang|en|''IM Used''}}
| IM Used
| RFC 3229 – Der Server hat eine GET-Anforderung für die Ressource erfüllt, die Antwort ist eine Darstellung des Ergebnisses von einer oder mehrerer Instanz-Manipulationen, bezogen auf die aktuelle Instanz
| RFC 3229 – Der Server hat eine GET-Anforderung für die Ressource erfüllt, die Antwort ist eine Darstellung des Ergebnisses von einer oder mehrerer Instanz-Manipulationen, bezogen auf die aktuelle Instanz
|}
|}
Zeile 127: Zeile 147:
=== 3xx – Umleitung ===
=== 3xx – Umleitung ===
Um eine erfolgreiche Bearbeitung der Anfrage sicherzustellen, sind weitere Schritte seitens des Clients erforderlich
Um eine erfolgreiche Bearbeitung der Anfrage sicherzustellen, sind weitere Schritte seitens des Clients erforderlich
{| class="wikitable"
{| class="wikitable"
|-
|-
Zeile 135: Zeile 154:
|-
|-
! 300
! 300
| {{lang|en|''Multiple Choices''}}
| Multiple Choices
| Die angeforderte Ressource steht in verschiedenen Arten zur Verfügung. Die Antwort enthält eine Liste der verfügbaren Arten. Das „Location“-Header-Feld enthält eventuell die Adresse der vom Server bevorzugten Repräsentation
| Die angeforderte Ressource steht in verschiedenen Arten zur Verfügung.  
* Die Antwort enthält eine Liste der verfügbaren Arten.  
* Das „Location“-Header-Feld enthält eventuell die Adresse der vom Server bevorzugten Repräsentation
|-
|-
! 301
! 301
| {{lang|en|''Moved Permanently''}}
| Moved Permanently
| Die angeforderte Ressource steht ab sofort unter der im „Location“-Header-Feld angegebenen Adresse bereit (auch Redirect genannt). Die alte Adresse ist nicht länger gültig
| Die angeforderte Ressource steht ab sofort unter der im „Location“-Header-Feld angegebenen Adresse bereit (auch Redirect genannt).  
* Die alte Adresse ist nicht länger gültig
|-
|-
! 302
! 302
| {{lang|en|''Found''}} ({{lang|en|''Moved Temporarily''}})
| Found''}} ({{lang|en|''Moved Temporarily)
| Die angeforderte Ressource steht vorübergehend unter der im „Location“-Header-Feld angegebenen Adresse bereit. Die alte Adresse bleibt gültig. Die Browser folgen meist mit einem GET, auch wenn der ursprüngliche Request ein POST war. Wird in HTTP/1.1 je nach Anwendungsfall durch die Statuscodes 303 oder 307 ersetzt. 302-Weiterleitung ist aufgrund eines Suchmaschinen-Fehlers, des [[URL-Hijacking]]s, in Kritik geraten
| Die angeforderte Ressource steht vorübergehend unter der im „Location“-Header-Feld angegebenen Adresse bereit.  
* Die alte Adresse bleibt gültig.  
* Die Browser folgen meist mit einem GET, auch wenn der ursprüngliche Request ein POST war.  
* Wird in HTTP/1.1 je nach Anwendungsfall durch die Statuscodes 303 oder 307 ersetzt. 302-Weiterleitung ist aufgrund eines Suchmaschinen-Fehlers, des [[URL-Hijacking]]s, in Kritik geraten
|-
|-
! 303
! 303
| {{lang|en|''See Other''}}
| See Other
| Die Antwort auf die durchgeführte Anfrage lässt sich unter der im „Location“-Header-Feld angegebenen Adresse beziehen. Der Browser soll mit einem GET folgen, auch wenn der ursprüngliche Request ein POST war
| Die Antwort auf die durchgeführte Anfrage lässt sich unter der im „Location“-Header-Feld angegebenen Adresse beziehen.  
* Der Browser soll mit einem GET folgen, auch wenn der ursprüngliche Request ein POST war
|-
|-
! 304
! 304
| {{lang|en|''Not Modified''}}
| Not Modified
| Der Inhalt der angeforderten Ressource hat sich seit der letzten Abfrage des Clients nicht verändert und wird deshalb nicht übertragen. Zu den Einzelheiten siehe [[Browser-Cache #Versionsvergleich|Browser-Cache-Versionsvergleich]]
| Der Inhalt der angeforderten Ressource hat sich seit der letzten Abfrage des Clients nicht verändert und wird deshalb nicht übertragen.  
* Zu den Einzelheiten siehe [[Browser-Cache #Versionsvergleich|Browser-Cache-Versionsvergleich]]
|-
|-
! 305
! 305
| {{lang|en|''Use Proxy''}}
| Use Proxy
| Die angeforderte Ressource ist nur über einen Proxy erreichbar. Das „Location“-Header-Feld enthält die Adresse des Proxys
| Die angeforderte Ressource ist nur über einen Proxy erreichbar.  
* Das „Location“-Header-Feld enthält die Adresse des Proxys
|-
|-
! 306
! 306
| {{lang|en|''(reserviert)''}}
| (reserviert)
| 306 wird nicht mehr verwendet, ist aber reserviert. Es wurde für „Switch Proxy“ verwendet
| 306 wird nicht mehr verwendet, ist aber reserviert.  
* Es wurde für „Switch Proxy“ verwendet
|-
|-
! 307
! 307
| {{lang|en|''Temporary Redirect''}}
| Temporary Redirect
| Die angeforderte Ressource steht vorübergehend unter der im „Location“-Header-Feld angegebenen Adresse bereit. Die alte Adresse bleibt gültig. Der Browser soll mit ''derselben'' Methode folgen wie beim ursprünglichen Request (d.&nbsp;h. einem POST folgt ein POST). Dies ist der wesentliche Unterschied zu 302/303
| Die angeforderte Ressource steht vorübergehend unter der im „Location“-Header-Feld angegebenen Adresse bereit.  
* Die alte Adresse bleibt gültig.  
* Der Browser soll mit ''derselben'' Methode folgen wie beim ursprünglichen Request (d.&nbsp;h.  
* einem POST folgt ein POST).  
* Dies ist der wesentliche Unterschied zu 302/303
|-
|-
! 308
! 308
| {{lang|en|''Permanent Redirect''}}
| Permanent Redirect
| Die angeforderte Ressource steht ab sofort unter der im „Location“-Header-Feld angegebenen Adresse bereit, die alte Adresse ist nicht länger gültig. Der Browser soll mit ''derselben'' Methode folgen wie beim ursprünglichen Request (d.&nbsp;h. einem POST folgt ein POST). Dies ist der wesentliche Unterschied zu 301
| Die angeforderte Ressource steht ab sofort unter der im „Location“-Header-Feld angegebenen Adresse bereit, die alte Adresse ist nicht länger gültig.  
* Der Browser soll mit ''derselben'' Methode folgen wie beim ursprünglichen Request (d.&nbsp;h.  
* einem POST folgt ein POST).  
* Dies ist der wesentliche Unterschied zu 301
|}
|}


Zeile 181: Zeile 217:
|-
|-
! 400
! 400
| {{lang|en|''Bad Request''}}
| Bad Request
| Die Anfrage-Nachricht war fehlerhaft aufgebaut
| Die Anfrage-Nachricht war fehlerhaft aufgebaut
|-
|-
! 401
! 401
| {{lang|en|''Unauthorized''}}
| Unauthorized
| Die Anfrage kann nicht ohne gültige Authentifizierung durchgeführt werden. Wie die Authentifizierung durchgeführt werden soll, wird im „WWW-Authenticate“-Header-Feld der Antwort übermittelt
| Die Anfrage kann nicht ohne gültige Authentifizierung durchgeführt werden.  
* Wie die Authentifizierung durchgeführt werden soll, wird im „WWW-Authenticate“-Header-Feld der Antwort übermittelt
|-
|-
! 402
! 402
| {{lang|en|''Payment Required''}}
| Payment Required
| Bezahlung benötigt. Dieser Status ist für zukünftige HTTP-Protokolle reserviert
| Bezahlung benötigt.  
* Dieser Status ist für zukünftige HTTP-Protokolle reserviert
|-
|-
! 403
! 403
| {{lang|en|''Forbidden''}}
| Forbidden
| Die Anfrage wurde mangels Berechtigung des Clients nicht durchgeführt, bspw. weil der authentifizierte Benutzer nicht berechtigt ist oder eine als HTTPS konfigurierte URL nur mit HTTP aufgerufen wurde
| Die Anfrage wurde mangels Berechtigung des Clients nicht durchgeführt, bspw.  
* weil der authentifizierte Benutzer nicht berechtigt ist oder eine als HTTPS konfigurierte URL nur mit HTTP aufgerufen wurde
|-
|-
! 404
! 404
| {{lang|en|''Not Found''}}
| Not Found
| Die angeforderte Ressource wurde nicht gefunden. Dieser Statuscode kann ebenfalls verwendet werden, um eine Anfrage ohne näheren Grund abzuweisen. Links, die auf solche Fehlerseiten verweisen, werden auch als [[Toter Link|Tote Links]] bezeichnet. „404“ gilt zudem als verbreitetes [[Memes|Meme]]
| Die angeforderte Ressource wurde nicht gefunden.  
* Dieser Statuscode kann ebenfalls verwendet werden, um eine Anfrage ohne näheren Grund abzuweisen.  
* Links, die auf solche Fehlerseiten verweisen, werden auch als [[Toter Link|Tote Links]] bezeichnet. „404“ gilt zudem als verbreitetes [[Memes|Meme]]
|-
|-
! 405
! 405
| {{lang|en|''Method Not Allowed''}}
| Method Not Allowed
| Die Anfrage darf nur mit anderen HTTP-Methoden (zum Beispiel GET statt POST) gestellt werden. Gültige Methoden für die betreffende Ressource werden im „Allow“-Header-Feld der Antwort übermittelt
| Die Anfrage darf nur mit anderen HTTP-Methoden (zum Beispiel GET statt POST) gestellt werden.  
* Gültige Methoden für die betreffende Ressource werden im „Allow“-Header-Feld der Antwort übermittelt
|-
|-
! 406
! 406
| {{lang|en|''Not Acceptable''}}
| Not Acceptable
| Die angeforderte Ressource steht nicht in der gewünschten Form zur Verfügung. Gültige „Content-Type“-Werte können in der Antwort übermittelt werden
| Die angeforderte Ressource steht nicht in der gewünschten Form zur Verfügung.  
* Gültige „Content-Type“-Werte können in der Antwort übermittelt werden
|-
|-
! 407
! 407
| {{lang|en|''Proxy Authentication Required''}}
| Proxy Authentication Required
| Analog zum Statuscode 401 ist hier zunächst eine Authentifizierung des Clients gegenüber dem verwendeten Proxy erforderlich. Wie die Authentifizierung durchgeführt werden soll, wird im „Proxy-Authenticate“-Header-Feld der Antwort übermittelt
| Analog zum Statuscode 401 ist hier zunächst eine Authentifizierung des Clients gegenüber dem verwendeten Proxy erforderlich.  
* Wie die Authentifizierung durchgeführt werden soll, wird im „Proxy-Authenticate“-Header-Feld der Antwort übermittelt
|-
|-
! 408
! 408
| {{lang|en|''Request Timeout''}}
| Request Timeout
| Innerhalb der vom Server erlaubten Zeitspanne wurde keine vollständige Anfrage des Clients empfangen
| Innerhalb der vom Server erlaubten Zeitspanne wurde keine vollständige Anfrage des Clients empfangen
|-
|-
! 409
! 409
| {{lang|en|''Conflict''}}
| Conflict
| Die Anfrage wurde unter falschen Annahmen gestellt. Im Falle einer PUT-Anfrage kann dies zum Beispiel auf eine zwischenzeitliche Veränderung der Ressource durch Dritte zurückgehen
| Die Anfrage wurde unter falschen Annahmen gestellt.  
* Im Falle einer PUT-Anfrage kann dies zum Beispiel auf eine zwischenzeitliche Veränderung der Ressource durch Dritte zurückgehen
|-
|-
! 410
! 410
| {{lang|en|''Gone''}}
| Gone
| Die angeforderte Ressource wird nicht länger bereitgestellt und wurde dauerhaft entfernt
| Die angeforderte Ressource wird nicht länger bereitgestellt und wurde dauerhaft entfernt
|-
|-
! 411
! 411
| {{lang|en|''Length Required''}}
| Length Required
| Die Anfrage kann ohne ein „Content-Length“-Header-Feld nicht bearbeitet werden
| Die Anfrage kann ohne ein „Content-Length“-Header-Feld nicht bearbeitet werden
|-
|-
! 412
! 412
| {{lang|en|''Precondition Failed''}}
| Precondition Failed
| Eine in der Anfrage übertragene Voraussetzung, zum Beispiel in Form eines „If-Match“-Header-Felds, traf nicht zu
| Eine in der Anfrage übertragene Voraussetzung, zum Beispiel in Form eines „If-Match“-Header-Felds, traf nicht zu
|-
|-
! 413
! 413
| {{lang|en|''Payload Too Large''}}
| Payload Too Large
| Die gestellte Anfrage war zu groß, um vom Server bearbeitet werden zu können. Ein „Retry-After“-Header-Feld in der Antwort kann den Client darauf hinweisen, dass die Anfrage eventuell zu einem späteren Zeitpunkt bearbeitet werden könnte
| Die gestellte Anfrage war zu groß, um vom Server bearbeitet werden zu können.  
* Ein „Retry-After“-Header-Feld in der Antwort kann den Client darauf hinweisen, dass die Anfrage eventuell zu einem späteren Zeitpunkt bearbeitet werden könnte
|-
|-
! 414
! 414
| {{lang|en|''URI Too Long''}}
| URI Too Long
| Die URL der Anfrage war zu lang. Ursache ist oft eine Endlosschleife aus Redirects
| Die URL der Anfrage war zu lang.  
* Ursache ist oft eine Endlosschleife aus Redirects
|-
|-
! 415
! 415
| {{lang|en|''Unsupported Media Type''}}
| Unsupported Media Type
| Der Inhalt der Anfrage wurde mit ungültigem oder nicht erlaubtem Medientyp übermittelt
| Der Inhalt der Anfrage wurde mit ungültigem oder nicht erlaubtem Medientyp übermittelt
|-
|-
! 416
! 416
| {{lang|en|''Range Not Satisfiable''}}
| Range Not Satisfiable
| Der angeforderte Teil einer Ressource war ungültig oder steht auf dem Server nicht zur Verfügung
| Der angeforderte Teil einer Ressource war ungültig oder steht auf dem Server nicht zur Verfügung
|-
|-
! 417
! 417
| {{lang|en|''Expectation Failed''}}
| Expectation Failed
| Verwendet im Zusammenhang mit einem „Expect“-Header-Feld. Das im „Expect“-Header-Feld geforderte Verhalten des Servers kann nicht erfüllt werden
| Verwendet im Zusammenhang mit einem „Expect“-Header-Feld.  
* Das im „Expect“-Header-Feld geforderte Verhalten des Servers kann nicht erfüllt werden
|-
|-
! 421
! 421
| {{lang|en|''Misdirected Request''}}
| Misdirected Request
| Die Anfrage wurde an einen Server gesendet, der nicht in der Lage ist, eine Antwort zu senden. Eingeführt in [[HTTP/2]]
| Die Anfrage wurde an einen Server gesendet, der nicht in der Lage ist, eine Antwort zu senden.  
* Eingeführt in [[HTTP/2]]
|-
|-
! 422
! 422
| {{lang|en|''Unprocessable Entity''}}
| Unprocessable Entity
| Verwendet, wenn weder die Rückgabe von Statuscode 415 noch 400 gerechtfertigt wäre, eine Verarbeitung der Anfrage jedoch zum Beispiel wegen [[Semantik|semantischer]] Fehler abgelehnt wird
| Verwendet, wenn weder die Rückgabe von Statuscode 415 noch 400 gerechtfertigt wäre, eine Verarbeitung der Anfrage jedoch zum Beispiel wegen [[Semantik|semantischer]] Fehler abgelehnt wird
|-
|-
! 423
! 423
| {{lang|en|''Locked''}}
| Locked
| Die angeforderte Ressource ist zurzeit gesperrt
| Die angeforderte Ressource ist zurzeit gesperrt
|-
|-
! 424
! 424
| {{lang|en|''Failed Dependency''}}
| Failed Dependency
| Die Anfrage konnte nicht durchgeführt werden, weil sie das Gelingen einer anderen Anfrage voraussetzt
| Die Anfrage konnte nicht durchgeführt werden, weil sie das Gelingen einer anderen Anfrage voraussetzt
|-
|-
! 425
! 425
| {{lang|en|''Too Early''}}
| Too Early
| Der Server bittet den Client die Anfrage erneut zu senden, da die TLS-Verbindung noch nicht vollständig hergestellt wurde. Dies soll einen [[Replay-Angriff]] verhindern
| Der Server bittet den Client die Anfrage erneut zu senden, da die TLS-Verbindung noch nicht vollständig hergestellt wurde.  
* Dies soll einen [[Replay-Angriff]] verhindern
|-
|-
! 426
! 426
| {{lang|en|''Upgrade Required''}}
| Upgrade Required
| Der Server verlangt vom Client, dass er die Anfrage mit einem anderen Protokoll wiederholt
| Der Server verlangt vom Client, dass er die Anfrage mit einem anderen Protokoll wiederholt
|-
|-
! 428
! 428
| {{lang|en|''Precondition Required''}}
| Precondition Required
| Für die Anfrage waren nicht alle Vorbedingungen erfüllt. Dieser Statuscode soll Probleme durch [[Race Condition]]s verhindern, indem eine Manipulation oder Löschen nur erfolgt, wenn der Client dies auf Basis einer aktuellen Ressource anfordert (Beispielsweise durch Mitliefern eines aktuellen [[HTTP ETag|ETag-Header]])
| Für die Anfrage waren nicht alle Vorbedingungen erfüllt.  
* Dieser Statuscode soll Probleme durch [[Race Condition]]s verhindern, indem eine Manipulation oder Löschen nur erfolgt, wenn der Client dies auf Basis einer aktuellen Ressource anfordert (Beispielsweise durch Mitliefern eines aktuellen [[HTTP ETag|ETag-Header]])
|-
|-
! 429
! 429
| {{lang|en|''Too Many Requests''}}
| Too Many Requests
| Der Client hat zu viele Anfragen in einem bestimmten Zeitraum gesendet
| Der Client hat zu viele Anfragen in einem bestimmten Zeitraum gesendet
|-
|-
! 431
! 431
| {{lang|en|''Request Header Fields Too Large''}}
| Request Header Fields Too Large
| Die Maximallänge eines Headerfelds oder des Gesamtheaders wurde überschritten
| Die Maximallänge eines Headerfelds oder des Gesamtheaders wurde überschritten
|-
|-
! 451
! 451
| {{lang|en|''Unavailable For Legal Reasons''}}
| Unavailable For Legal Reasons
| Dieser Statuscode soll darauf hinweisen, dass die angeforderte Ressource aufgrund von gesetzlichen Bestimmungen (Copyrighteinschränkungen, Zensur etc., eventuell beschränkt auf ein bestimmtes Land) nicht verfügbar ist
| Dieser Statuscode soll darauf hinweisen, dass die angeforderte Ressource aufgrund von gesetzlichen Bestimmungen (Copyrighteinschränkungen, Zensur etc., eventuell beschränkt auf ein bestimmtes Land) nicht verfügbar ist
Er wurde im Juni 2012 von Google-Mitarbeiter [[Tim Bray]] bei der [[Internet Engineering Task Force|IETF]] eingereicht
Er wurde im Juni 2012 von Google-Mitarbeiter [[Tim Bray]] bei der [[Internet Engineering Task Force|IETF]] eingereicht
und gilt seit dem 17. Dezember 2015 als angenommen.
und gilt seit dem 17.  
* Dezember 2015 als angenommen.
Bray schlug die Nummer 451 in Anspielung auf [[Ray Bradbury]]s Roman [[Fahrenheit 451]] vor und fügte einen Dank an den Autor an
Bray schlug die Nummer 451 in Anspielung auf [[Ray Bradbury]]s Roman [[Fahrenheit 451]] vor und fügte einen Dank an den Autor an
|-
|-
Zeile 298: Zeile 350:
|-
|-
! 418
! 418
| {{lang|en|''I’m a teapot''}}
| I’m a teapot
| Dieser Code ist als [[Aprilscherz]] der [[Internet Engineering Task Force|IETF]] zu verstehen. Innerhalb eines scherzhaften Protokolls zum Kaffeekochen, des [[Hyper Text Coffee Pot Control Protocol]]s
| Dieser Code ist als [[Aprilscherz]] der [[Internet Engineering Task Force|IETF]] zu verstehen.  
zeigt er an, dass fälschlicherweise eine [[Teekanne]] anstatt einer [[Kaffeekanne]] verwendet wurde. Dieser Scherz-Statuscode ist auf einigen Websites zu finden, obwohl er weder Bestandteil von HTTP ist noch in der ''Status Code Registry'' definiert ist. Er soll zukünftig als „reserviert“ gelistet werden
* Innerhalb eines scherzhaften Protokolls zum Kaffeekochen, des [[Hyper Text Coffee Pot Control Protocol]]s
zeigt er an, dass fälschlicherweise eine [[Teekanne]] anstatt einer [[Kaffeekanne]] verwendet wurde.  
* Dieser Scherz-Statuscode ist auf einigen Websites zu finden, obwohl er weder Bestandteil von HTTP ist noch in der ''Status Code Registry'' definiert ist.  
* Er soll zukünftig als „reserviert“ gelistet werden
|-
|-
! 420
! 420
| {{lang|en|''Policy Not Fulfilled''}}
| Policy Not Fulfilled
| In [[W3C]] PEP (Working Draft 21. November 1997) wird dieser Code vorgeschlagen, um mitzuteilen, dass eine Bedingung nicht erfüllt wurde
| In [[W3C]] PEP (Working Draft 21.  
* November 1997) wird dieser Code vorgeschlagen, um mitzuteilen, dass eine Bedingung nicht erfüllt wurde
|-
|-
! 444
! 444
| {{lang|en|''No Response''}}
| No Response
| In [[nginx]]-Logs verwendet, um anzuzeigen, dass der Server keine Informationen zum Client zurückgesendet und die Verbindung geschlossen hat
| In [[nginx]]-Logs verwendet, um anzuzeigen, dass der Server keine Informationen zum Client zurückgesendet und die Verbindung geschlossen hat
|-
|-
! 449
! 449
| {{lang|en|''The request should be retried after doing the appropriate action''}}
| The request should be retried after doing the appropriate action
| Genutzt in Antworten des [[Microsoft Exchange Server]]s
| Genutzt in Antworten des [[Microsoft Exchange Server]]s
|-
|-
! 499
! 499
| {{lang|en|''Client Closed Request''}}
| Client Closed Request
| Ein nicht standardmäßiger Statuscode, der von [[nginx]] für den Fall eingeführt wurde, dass ein Client die Verbindung schließt, während nginx die Anforderung verarbeitet
| Ein nicht standardmäßiger Statuscode, der von [[nginx]] für den Fall eingeführt wurde, dass ein Client die Verbindung schließt, während nginx die Anforderung verarbeitet
|}
|}


=== 5xx – Server-Fehler ===
=== 5xx – Server-Fehler ===
Nicht klar von den so genannten [[Client]]-Fehlern abzugrenzen. Die Ursache des Scheiterns der Anfrage liegt jedoch eher im Verantwortungsbereich des Servers
Nicht klar von den so genannten [[Client]]-Fehlern abzugrenzen.  
* Die Ursache des Scheiterns der Anfrage liegt jedoch eher im Verantwortungsbereich des Servers


{| class="wikitable"
{| class="wikitable"
Zeile 329: Zeile 386:
|-
|-
! 500
! 500
| {{lang|en|''Internal Server Error''}}
| Internal Server Error
| Dies ist ein „Sammel-Statuscode“ für unerwartete Serverfehler
| Dies ist ein „Sammel-Statuscode“ für unerwartete Serverfehler
|-
|-
! 501
! 501
| {{lang|en|''Not Implemented''}}
| Not Implemented
| Die Funktionalität, um die Anfrage zu bearbeiten, wird von diesem Server nicht bereitgestellt. Ursache ist zum Beispiel eine unbekannte oder nicht unterstützte HTTP-Methode
| Die Funktionalität, um die Anfrage zu bearbeiten, wird von diesem Server nicht bereitgestellt.  
* Ursache ist zum Beispiel eine unbekannte oder nicht unterstützte HTTP-Methode
|-
|-
! 502
! 502
| {{lang|en|''Bad Gateway''}}
| Bad Gateway
| Der Server konnte seine Funktion als Gateway oder Proxy nicht erfüllen, weil er seinerseits eine ungültige Antwort erhalten hat
| Der Server konnte seine Funktion als Gateway oder Proxy nicht erfüllen, weil er seinerseits eine ungültige Antwort erhalten hat
|-
|-
! 503
! 503
| {{lang|en|''Service Unavailable''}}
| Service Unavailable
| Der Server steht temporär nicht zur Verfügung, zum Beispiel wegen Überlastung oder Wartungsarbeiten. Ein „Retry-After“-Header-Feld in der Antwort kann den Client auf einen Zeitpunkt hinweisen, zu dem die Anfrage eventuell bearbeitet werden könnte
| Der Server steht temporär nicht zur Verfügung, zum Beispiel wegen Überlastung oder Wartungsarbeiten.  
* Ein „Retry-After“-Header-Feld in der Antwort kann den Client auf einen Zeitpunkt hinweisen, zu dem die Anfrage eventuell bearbeitet werden könnte
|-
|-
! 504
! 504
| {{lang|en|''Gateway Timeout''}}
| Gateway Timeout
| Der Server konnte seine Funktion als Gateway oder Proxy nicht erfüllen, weil er innerhalb einer festgelegten Zeitspanne keine Antwort von seinerseits benutzten Servern oder Diensten erhalten hat
| Der Server konnte seine Funktion als Gateway oder Proxy nicht erfüllen, weil er innerhalb einer festgelegten Zeitspanne keine Antwort von seinerseits benutzten Servern oder Diensten erhalten hat
|-
|-
! 505
! 505
| {{lang|en|''HTTP Version not supported''}}
| HTTP Version not supported
| Die benutzte HTTP-Version (gemeint ist die Zahl vor dem Punkt) wird vom Server nicht unterstützt oder abgelehnt
| Die benutzte HTTP-Version (gemeint ist die Zahl vor dem Punkt) wird vom Server nicht unterstützt oder abgelehnt
|-
|-
! 506
! 506
| {{lang|en|''Variant Also Negotiates''}}
| Variant Also Negotiates
| Die [[Inhaltsvereinbarung]] der Anfrage ergibt einen [[Zirkelbezug]]
| Die [[Inhaltsvereinbarung]] der Anfrage ergibt einen [[Zirkelbezug]]
|-
|-
! 507
! 507
| {{lang|en|''Insufficient Storage''}}
| Insufficient Storage
| Die Anfrage konnte nicht bearbeitet werden, weil der Speicherplatz des Servers dazu derzeit nicht mehr ausreicht
| Die Anfrage konnte nicht bearbeitet werden, weil der Speicherplatz des Servers dazu derzeit nicht mehr ausreicht
|-
|-
! 508
! 508
| {{lang|en|''Loop Detected''}}
| Loop Detected
| Die Operation wurde nicht ausgeführt, weil die Ausführung in eine [[Endlosschleife]] gelaufen wäre. Definiert in der Binding-Erweiterung für WebDAV gemäß RFC 5842, weil durch Bindings zyklische Pfade zu WebDAV-Ressourcen entstehen können
| Die Operation wurde nicht ausgeführt, weil die Ausführung in eine [[Endlosschleife]] gelaufen wäre.  
* Definiert in der Binding-Erweiterung für WebDAV gemäß RFC 5842, weil durch Bindings zyklische Pfade zu WebDAV-Ressourcen entstehen können
|-
|-
! 509
! 509
| {{lang|en|''Bandwidth Limit Exceeded''}}
| Bandwidth Limit Exceeded
| Die Anfrage wurde verworfen, weil sonst die verfügbare Bandbreite überschritten würde (inoffizielle Erweiterung einiger Server)
| Die Anfrage wurde verworfen, weil sonst die verfügbare Bandbreite überschritten würde (inoffizielle Erweiterung einiger Server)
|-
|-
! 510
! 510
| {{lang|en|''Not Extended''}}
| Not Extended
| Die Anfrage enthält nicht alle Informationen, welche die angefragte Server-Extension zwingend erwartet
| Die Anfrage enthält nicht alle Informationen, welche die angefragte Server-Extension zwingend erwartet
|-
|-
! 511
! 511
| {{lang|en|''Network Authentication Required''}}
| Network Authentication Required
| Der Client muss sich zuerst authentifizieren, um Zugang zum Netzwerk zu erhalten
| Der Client muss sich zuerst authentifizieren, um Zugang zum Netzwerk zu erhalten
|}
|}
Zeile 379: Zeile 439:
=== 9xx – Proprietäre Fehler ===
=== 9xx – Proprietäre Fehler ===
Manche Softwarehersteller verwenden den Bereich ab 900 für [[proprietär]]e Statuscodes
Manche Softwarehersteller verwenden den Bereich ab 900 für [[proprietär]]e Statuscodes
Dieser Zahlenbereich wurde in den RFC-Dokumenten nie erwähnt und liegt offensichtlich jenseits der standardisierten Codes. Dadurch ist er leicht als Sonderfall erkennbar
Dieser Zahlenbereich wurde in den RFC-Dokumenten nie erwähnt und liegt offensichtlich jenseits der standardisierten Codes.  
* Dadurch ist er leicht als Sonderfall erkennbar


<noinclude>
<noinclude>
== Anhang ==
== Anhang ==
=== Siehe auch ===
=== Siehe auch ===
Zeile 393: Zeile 455:
==== Links ====
==== Links ====
===== Weblinks =====
===== Weblinks =====
* [https://www.iana.org/assignments/http-status-codes Hypertext Transfer Protocol (HTTP) Status Code Registry] auf der Website der [[Internet Assigned Numbers Authority|IANA]]
# [https://www.iana.org/assignments/http-status-codes Hypertext Transfer Protocol (HTTP) Status Code Registry] auf der Website der [[Internet Assigned Numbers Authority|IANA]]
* [https://support.microsoft.com/?id=318380 Microsoft Internet Information Server Status Codes and Sub-Codes] bei ''support.microsoft.com''
# [https://support.microsoft.com/?id=318380 Microsoft Internet Information Server Status Codes and Sub-Codes] bei ''support.microsoft.com''
* {{Webarchiv|url=http://livedocs.adobe.com/fms/2/docs/wwhelp/wwhimpl/common/html/wwhelp.htm?context=LiveDocs_Parts&file=00000338.html | wayback=20100130150919 | text=Adobe Flash status code definitions (ie 408)}} auf der Website von [[Adobe Inc.]]
# [https://www.askapache.com/htaccess/apache-status-code-headers-errordocument/ apache-status-code-headers] bei ''askapache.com''
* [https://www.askapache.com/htaccess/apache-status-code-headers-errordocument/ apache-status-code-headers] bei ''askapache.com''
# Roy Fielding, Julian Reschke: [[rfc:7231#section-6.3.4|Section 6.3.4 – ''Response Status Codes'']].  
* Roy Fielding, Julian Reschke: [[rfc:7231#section-6.3.4|Section 6.3.4 – ''Response Status Codes'']]. RFC 7231 – ''Hypertext Transfer Protocol'' (HTTP/1.1), [[IETF]], Juni 2014
# RFC 7231 – ''Hypertext Transfer Protocol'' (HTTP/1.1), [[IETF]], Juni 2014


[[Kategorie:HTTP]]
[[Kategorie:HTTP]]
</noinclude>
</noinclude>

Aktuelle Version vom 13. Oktober 2024, 10:17 Uhr

HTTP-Statuscode - Rückmeldungen eines Webservers

Beschreibung

Beispiel einer Webseite, die von einem Webserver zusätzlich zum 404 Statuscode gesendet wurde.
Jede HTTP-Anfrage wird vom Server mit einem HTTP-Statuscode beantwortet
  • ob die Anfrage erfolgreich bearbeitet wurde
  • teilt dem Client/Browser im Fehlerfall mit, wo (etwa Umleitung) oder wie (zum Beispiel mit Authentifizierung) er die gewünschten Informationen (wenn möglich) erhalten kann
HTTP-Statuscode
https://www.instagram.com/p/C37qsaiAHTn/

Ein HTTP-Statuscode wird von einem Server auf jede HTTP-Anfrage als Antwort geliefert.

  • Auf der anfragenden Seite steht dabei ein Client wie ein Webbrowser.
  • Der Server teilt durch den HTTP-Statuscode dem Client mit, ob die Anfrage erfolgreich bearbeitet wurde.
  • Im Fehlerfall gibt der Statuscode Auskunft darüber, wo (beispielsweise über eine Umleitung) oder wie (zum Beispiel mit Authentifizierung) er die gewünschten Informationen erhalten kann.
404: „Nicht gefunden“
  • Am bekanntesten sind dabei die Codes 404: „Nicht gefunden“, 403: „Fehlende Zugriffsberechtigung“ und 400: „Fehlerhafte Anfrage“
Statusklassen

Die erste Ziffer eines Statuscodes stellt die Statusklasse dar.

  • Sie sind in RFC 7231 (ersetzt RFC 2616), sowie RFC 2518, RFC 2817, RFC 2295, RFC 2774 und RFC 4918 spezifiziert.
  • Einige gehören zum Distributed Authoring (WebDAV)

Neben den in RFC standardisierten Statuscodes verwenden manche Softwarehersteller auch proprietäre Codes für eigens definierte Status- und Fehlermeldungen.

  • Andere Software kann dem Benutzer diese Codes nur als allgemeinen unbekannten Fehler anzeigen; nicht aber eine Übersetzung und Hinweise zum weiteren Vorgehen.
  • Teilweise können die Server den Begleitumständen der Anfrage bereits entnehmen, dass es sich um die zugehörige Spezialsoftware handelt, und geben nur dann die proprietären Codes zurück.
  • In diesem Artikel sind einige proprietäre Codes aufgeführt und entsprechend gekennzeichnet
Codes  Klasse Beschreibung
1xx Informationen Die Bearbeitung der Anfrage dauert trotz der Rückmeldung noch an
  • Eine solche Zwischenantwort ist manchmal notwendig, da viele Clients nach einer bestimmten Zeitspanne (Zeitüberschreitung) automatisch annehmen, dass ein Fehler bei der Übertragung oder Verarbeitung der Anfrage aufgetreten ist, und mit einer Fehlermeldung abbrechen
2xx Erfolg Die Anfrage wurde bearbeitet und die Antwort wird an den Anfragesteller zurückgesendet
3xx Umleitung Um eine erfolgreiche Bearbeitung der Anfrage sicherzustellen, sind weitere Schritte seitens des Clients erforderlich
  • Das ist etwa der Fall, wenn eine Webseite vom Betreiber umgestaltet wurde, sodass sich eine gewünschte Datei nun an einem anderen Platz befindet
  • Mit der Antwort des Servers erfährt der Client im Location-Header, wo sich die Datei jetzt befindet
4xx Client-Fehler Bei der Bearbeitung der Anfrage ist ein Fehler aufgetreten, der im Verantwortungsbereich des Clients liegt
  • Ein 404 tritt etwa ein, wenn ein Dokument angefragt wurde, das auf dem Server nicht existiert
  • Ein 403 weist den Client darauf hin, dass es ihm nicht erlaubt ist, das jeweilige Dokument abzurufen
  • Es kann sich zum Beispiel um ein vertrauliches oder nur per HTTPS zugängliches Dokument handeln
5xx Server-Fehler Es ist ein Fehler aufgetreten, dessen Ursache beim Server liegt
  • Zum Beispiel bedeutet 501, dass der Server nicht über die erforderlichen Funktionen (das heißt etwa Programme oder andere Dateien) verfügt, um die Anfrage zu bearbeiten
9xx Proprietäre Fehler

Zusätzlich zum Statuscode enthält der Header der Server-Antwort eine Beschreibung des Fehlers in englischsprachigem Klartext

Mit Fehler 404 kommen Web-Nutzer am häufigsten in Berührung

Zum Beispiel ist ein Fehler 404 an folgendem Header zu erkennen:

HTTP/1.1 404 Not Found

HTTP-Statuscodes

1xx – Informationen

Die Bearbeitung der Anfrage dauert noch an

Code Nachricht Bedeutung
100 Continue Die laufende Anfrage an den Server wurde noch nicht zurückgewiesen. (Wird im Zusammenhang mit dem „Expect 100-continue“-Header-Feld verwendet.) Der Client kann nun mit der potentiell sehr großen Anfrage fortfahren
101 Switching Protocols Wird verwendet, wenn der Server eine Anfrage mit gesetztem „Upgrade“-Header-Feld empfangen hat und mit dem Wechsel zu einem anderen Protokoll einverstanden ist.
  • Anwendung findet dieser Status-Code beispielsweise im Wechsel von HTTP zu WebSocket
102 Processing Wird verwendet, um ein Timeout zu vermeiden, während der Server eine zeitintensive Anfrage bearbeitet.
  • Dies ist eine Interim-Antwort, auf die auf derselben Verbindung ohne weitere Client-Anfrage eine endgültige Antwort folgen muss
103 Early Hints Wird zusammen mit dem „Link“ Header verwendet, um das Vorladen von Ressourcen zu ermöglichen, während der Server die finale Antwort noch vorbereitet

2xx – Erfolgreiche Operation

Die Anfrage war erfolgreich, die Antwort kann verwertet werden

Code Nachricht Bedeutung
200 OK Die Anfrage wurde erfolgreich bearbeitet und das Ergebnis der Anfrage wird in der Antwort übertragen
201 Created Die Anfrage wurde erfolgreich bearbeitet.
  • Die angeforderte Ressource wurde vor dem Senden der Antwort erstellt.
  • Das „Location“-Header-Feld enthält eventuell die Adresse der erstellten Ressource
202 Accepted Die Anfrage wurde akzeptiert, wird aber zu einem späteren Zeitpunkt ausgeführt.
  • Das Gelingen der Anfrage kann nicht garantiert werden
203 Non-Authoritative Information Der Server agiert als „Transforming Proxy“, erhielt eine 200 OK Antwort von der Quelle und antwortet mit einem veränderten Dokument der Quelle
204 No Content Die Anfrage wurde erfolgreich durchgeführt, die Antwort enthält jedoch bewusst keine Daten
205 Reset Content Die Anfrage wurde erfolgreich durchgeführt; der Client soll das Dokument neu aufbauen und Formulareingaben zurücksetzen
206 Partial Content Der angeforderte Teil wurde erfolgreich übertragen (wird im Zusammenhang mit einem „Content-Range“-Header-Feld oder dem Content-Type multipart/byteranges verwendet).
  • Kann einen Client über Teil-Downloads informieren (wird zum Beispiel von Wget genutzt, um den Downloadfortschritt zu überwachen oder einen Download in mehrere Streams aufzuteilen)
207 Multi-Status WebDAV RFC 4918 – Die Antwort enthält ein in WebDAV spezifiziertes XML-Dokument, das mehrere Statuscodes zu unabhängig voneinander durchgeführten Operationen enthält
208 Already Reported WebDAV RFC 5842 – Die Mitglieder einer WebDAV-Bindung wurden bereits zuvor aufgezählt und sind in dieser Anfrage nicht mehr vorhanden
226 IM Used RFC 3229 – Der Server hat eine GET-Anforderung für die Ressource erfüllt, die Antwort ist eine Darstellung des Ergebnisses von einer oder mehrerer Instanz-Manipulationen, bezogen auf die aktuelle Instanz

3xx – Umleitung

Um eine erfolgreiche Bearbeitung der Anfrage sicherzustellen, sind weitere Schritte seitens des Clients erforderlich

Code Nachricht Bedeutung
300 Multiple Choices Die angeforderte Ressource steht in verschiedenen Arten zur Verfügung.
  • Die Antwort enthält eine Liste der verfügbaren Arten.
  • Das „Location“-Header-Feld enthält eventuell die Adresse der vom Server bevorzugten Repräsentation
301 Moved Permanently Die angeforderte Ressource steht ab sofort unter der im „Location“-Header-Feld angegebenen Adresse bereit (auch Redirect genannt).
  • Die alte Adresse ist nicht länger gültig
302 en|Moved Temporarily) Die angeforderte Ressource steht vorübergehend unter der im „Location“-Header-Feld angegebenen Adresse bereit.
  • Die alte Adresse bleibt gültig.
  • Die Browser folgen meist mit einem GET, auch wenn der ursprüngliche Request ein POST war.
  • Wird in HTTP/1.1 je nach Anwendungsfall durch die Statuscodes 303 oder 307 ersetzt. 302-Weiterleitung ist aufgrund eines Suchmaschinen-Fehlers, des URL-Hijackings, in Kritik geraten
303 See Other Die Antwort auf die durchgeführte Anfrage lässt sich unter der im „Location“-Header-Feld angegebenen Adresse beziehen.
  • Der Browser soll mit einem GET folgen, auch wenn der ursprüngliche Request ein POST war
304 Not Modified Der Inhalt der angeforderten Ressource hat sich seit der letzten Abfrage des Clients nicht verändert und wird deshalb nicht übertragen.
305 Use Proxy Die angeforderte Ressource ist nur über einen Proxy erreichbar.
  • Das „Location“-Header-Feld enthält die Adresse des Proxys
306 (reserviert) 306 wird nicht mehr verwendet, ist aber reserviert.
  • Es wurde für „Switch Proxy“ verwendet
307 Temporary Redirect Die angeforderte Ressource steht vorübergehend unter der im „Location“-Header-Feld angegebenen Adresse bereit.
  • Die alte Adresse bleibt gültig.
  • Der Browser soll mit derselben Methode folgen wie beim ursprünglichen Request (d. h.
  • einem POST folgt ein POST).
  • Dies ist der wesentliche Unterschied zu 302/303
308 Permanent Redirect Die angeforderte Ressource steht ab sofort unter der im „Location“-Header-Feld angegebenen Adresse bereit, die alte Adresse ist nicht länger gültig.
  • Der Browser soll mit derselben Methode folgen wie beim ursprünglichen Request (d. h.
  • einem POST folgt ein POST).
  • Dies ist der wesentliche Unterschied zu 301

4xx – Client-Fehler

Die Ursache des Scheiterns der Anfrage liegt (eher) im Verantwortungsbereich des Clients

Code Nachricht Bedeutung
400 Bad Request Die Anfrage-Nachricht war fehlerhaft aufgebaut
401 Unauthorized Die Anfrage kann nicht ohne gültige Authentifizierung durchgeführt werden.
  • Wie die Authentifizierung durchgeführt werden soll, wird im „WWW-Authenticate“-Header-Feld der Antwort übermittelt
402 Payment Required Bezahlung benötigt.
  • Dieser Status ist für zukünftige HTTP-Protokolle reserviert
403 Forbidden Die Anfrage wurde mangels Berechtigung des Clients nicht durchgeführt, bspw.
  • weil der authentifizierte Benutzer nicht berechtigt ist oder eine als HTTPS konfigurierte URL nur mit HTTP aufgerufen wurde
404 Not Found Die angeforderte Ressource wurde nicht gefunden.
  • Dieser Statuscode kann ebenfalls verwendet werden, um eine Anfrage ohne näheren Grund abzuweisen.
  • Links, die auf solche Fehlerseiten verweisen, werden auch als Tote Links bezeichnet. „404“ gilt zudem als verbreitetes Meme
405 Method Not Allowed Die Anfrage darf nur mit anderen HTTP-Methoden (zum Beispiel GET statt POST) gestellt werden.
  • Gültige Methoden für die betreffende Ressource werden im „Allow“-Header-Feld der Antwort übermittelt
406 Not Acceptable Die angeforderte Ressource steht nicht in der gewünschten Form zur Verfügung.
  • Gültige „Content-Type“-Werte können in der Antwort übermittelt werden
407 Proxy Authentication Required Analog zum Statuscode 401 ist hier zunächst eine Authentifizierung des Clients gegenüber dem verwendeten Proxy erforderlich.
  • Wie die Authentifizierung durchgeführt werden soll, wird im „Proxy-Authenticate“-Header-Feld der Antwort übermittelt
408 Request Timeout Innerhalb der vom Server erlaubten Zeitspanne wurde keine vollständige Anfrage des Clients empfangen
409 Conflict Die Anfrage wurde unter falschen Annahmen gestellt.
  • Im Falle einer PUT-Anfrage kann dies zum Beispiel auf eine zwischenzeitliche Veränderung der Ressource durch Dritte zurückgehen
410 Gone Die angeforderte Ressource wird nicht länger bereitgestellt und wurde dauerhaft entfernt
411 Length Required Die Anfrage kann ohne ein „Content-Length“-Header-Feld nicht bearbeitet werden
412 Precondition Failed Eine in der Anfrage übertragene Voraussetzung, zum Beispiel in Form eines „If-Match“-Header-Felds, traf nicht zu
413 Payload Too Large Die gestellte Anfrage war zu groß, um vom Server bearbeitet werden zu können.
  • Ein „Retry-After“-Header-Feld in der Antwort kann den Client darauf hinweisen, dass die Anfrage eventuell zu einem späteren Zeitpunkt bearbeitet werden könnte
414 URI Too Long Die URL der Anfrage war zu lang.
  • Ursache ist oft eine Endlosschleife aus Redirects
415 Unsupported Media Type Der Inhalt der Anfrage wurde mit ungültigem oder nicht erlaubtem Medientyp übermittelt
416 Range Not Satisfiable Der angeforderte Teil einer Ressource war ungültig oder steht auf dem Server nicht zur Verfügung
417 Expectation Failed Verwendet im Zusammenhang mit einem „Expect“-Header-Feld.
  • Das im „Expect“-Header-Feld geforderte Verhalten des Servers kann nicht erfüllt werden
421 Misdirected Request Die Anfrage wurde an einen Server gesendet, der nicht in der Lage ist, eine Antwort zu senden.
422 Unprocessable Entity Verwendet, wenn weder die Rückgabe von Statuscode 415 noch 400 gerechtfertigt wäre, eine Verarbeitung der Anfrage jedoch zum Beispiel wegen semantischer Fehler abgelehnt wird
423 Locked Die angeforderte Ressource ist zurzeit gesperrt
424 Failed Dependency Die Anfrage konnte nicht durchgeführt werden, weil sie das Gelingen einer anderen Anfrage voraussetzt
425 Too Early Der Server bittet den Client die Anfrage erneut zu senden, da die TLS-Verbindung noch nicht vollständig hergestellt wurde.
426 Upgrade Required Der Server verlangt vom Client, dass er die Anfrage mit einem anderen Protokoll wiederholt
428 Precondition Required Für die Anfrage waren nicht alle Vorbedingungen erfüllt.
  • Dieser Statuscode soll Probleme durch Race Conditions verhindern, indem eine Manipulation oder Löschen nur erfolgt, wenn der Client dies auf Basis einer aktuellen Ressource anfordert (Beispielsweise durch Mitliefern eines aktuellen ETag-Header)
429 Too Many Requests Der Client hat zu viele Anfragen in einem bestimmten Zeitraum gesendet
431 Request Header Fields Too Large Die Maximallänge eines Headerfelds oder des Gesamtheaders wurde überschritten
451 Unavailable For Legal Reasons Dieser Statuscode soll darauf hinweisen, dass die angeforderte Ressource aufgrund von gesetzlichen Bestimmungen (Copyrighteinschränkungen, Zensur etc., eventuell beschränkt auf ein bestimmtes Land) nicht verfügbar ist

Er wurde im Juni 2012 von Google-Mitarbeiter Tim Bray bei der IETF eingereicht und gilt seit dem 17.

  • Dezember 2015 als angenommen.

Bray schlug die Nummer 451 in Anspielung auf Ray Bradburys Roman Fahrenheit 451 vor und fügte einen Dank an den Autor an

Beispiele für weitere, per Juli 2020 nicht in der Hypertext Transfer Protocol (HTTP) Status Code Registry aufgeführte Codes:
418 I’m a teapot Dieser Code ist als Aprilscherz der IETF zu verstehen.

zeigt er an, dass fälschlicherweise eine Teekanne anstatt einer Kaffeekanne verwendet wurde.

  • Dieser Scherz-Statuscode ist auf einigen Websites zu finden, obwohl er weder Bestandteil von HTTP ist noch in der Status Code Registry definiert ist.
  • Er soll zukünftig als „reserviert“ gelistet werden
420 Policy Not Fulfilled In W3C PEP (Working Draft 21.
  • November 1997) wird dieser Code vorgeschlagen, um mitzuteilen, dass eine Bedingung nicht erfüllt wurde
444 No Response In nginx-Logs verwendet, um anzuzeigen, dass der Server keine Informationen zum Client zurückgesendet und die Verbindung geschlossen hat
449 The request should be retried after doing the appropriate action Genutzt in Antworten des Microsoft Exchange Servers
499 Client Closed Request Ein nicht standardmäßiger Statuscode, der von nginx für den Fall eingeführt wurde, dass ein Client die Verbindung schließt, während nginx die Anforderung verarbeitet

5xx – Server-Fehler

Nicht klar von den so genannten Client-Fehlern abzugrenzen.

  • Die Ursache des Scheiterns der Anfrage liegt jedoch eher im Verantwortungsbereich des Servers
Code Nachricht Bedeutung
500 Internal Server Error Dies ist ein „Sammel-Statuscode“ für unerwartete Serverfehler
501 Not Implemented Die Funktionalität, um die Anfrage zu bearbeiten, wird von diesem Server nicht bereitgestellt.
  • Ursache ist zum Beispiel eine unbekannte oder nicht unterstützte HTTP-Methode
502 Bad Gateway Der Server konnte seine Funktion als Gateway oder Proxy nicht erfüllen, weil er seinerseits eine ungültige Antwort erhalten hat
503 Service Unavailable Der Server steht temporär nicht zur Verfügung, zum Beispiel wegen Überlastung oder Wartungsarbeiten.
  • Ein „Retry-After“-Header-Feld in der Antwort kann den Client auf einen Zeitpunkt hinweisen, zu dem die Anfrage eventuell bearbeitet werden könnte
504 Gateway Timeout Der Server konnte seine Funktion als Gateway oder Proxy nicht erfüllen, weil er innerhalb einer festgelegten Zeitspanne keine Antwort von seinerseits benutzten Servern oder Diensten erhalten hat
505 HTTP Version not supported Die benutzte HTTP-Version (gemeint ist die Zahl vor dem Punkt) wird vom Server nicht unterstützt oder abgelehnt
506 Variant Also Negotiates Die Inhaltsvereinbarung der Anfrage ergibt einen Zirkelbezug
507 Insufficient Storage Die Anfrage konnte nicht bearbeitet werden, weil der Speicherplatz des Servers dazu derzeit nicht mehr ausreicht
508 Loop Detected Die Operation wurde nicht ausgeführt, weil die Ausführung in eine Endlosschleife gelaufen wäre.
  • Definiert in der Binding-Erweiterung für WebDAV gemäß RFC 5842, weil durch Bindings zyklische Pfade zu WebDAV-Ressourcen entstehen können
509 Bandwidth Limit Exceeded Die Anfrage wurde verworfen, weil sonst die verfügbare Bandbreite überschritten würde (inoffizielle Erweiterung einiger Server)
510 Not Extended Die Anfrage enthält nicht alle Informationen, welche die angefragte Server-Extension zwingend erwartet
511 Network Authentication Required Der Client muss sich zuerst authentifizieren, um Zugang zum Netzwerk zu erhalten

9xx – Proprietäre Fehler

Manche Softwarehersteller verwenden den Bereich ab 900 für proprietäre Statuscodes Dieser Zahlenbereich wurde in den RFC-Dokumenten nie erwähnt und liegt offensichtlich jenseits der standardisierten Codes.

  • Dadurch ist er leicht als Sonderfall erkennbar


Anhang

Siehe auch


Links

Weblinks
  1. Hypertext Transfer Protocol (HTTP) Status Code Registry auf der Website der IANA
  2. Microsoft Internet Information Server Status Codes and Sub-Codes bei support.microsoft.com
  3. apache-status-code-headers bei askapache.com
  4. Roy Fielding, Julian Reschke: Section 6.3.4 – Response Status Codes.
  5. RFC 7231 – Hypertext Transfer Protocol (HTTP/1.1), IETF, Juni 2014