Zeilenumbruch im HTTP-Header


161

Welcher Zeilenumbruchstil ist für die Verwendung in HTTP-Headern vorzuziehen: \r\noder \nund warum?

Antworten:


224

\r\n, weil es als Zeilenumbruch in der Protokollspezifikation definiert ist. RFC2616 stellt am Anfang von Abschnitt 2.2, "Grundregeln" , ganz eindeutig fest:

CR = <US-ASCII CR, Wagenrücklauf (13)>
LF = <US-ASCII LF, Zeilenvorschub (10)>
HTTP / 1.1 definiert die Sequenz CR LF als Zeilenende-Markierung für alle Protokollelemente mit Ausnahme der Entität -Körper

RFC2616 wurde von RFC7230 technisch überholt, nimmt jedoch keine drastischen Änderungen vor und ruft CRLF erneut als Trennzeichen in Abschnitt 3 auf . RFC verweist auf RFC5234, Anhang B.1 , um "CRLF" als zu definieren %x0D %x0A.

In Anbetracht der Tatsache , dass Personen gegen den Standard verstoßen, gibt es in Abschnitt 19.3 eine "Toleranzbestimmung" (beachten Sie, dass die richtige Reihenfolge wiederholt wird):

Der Zeilenabschluss für Nachrichtenkopffelder ist die Sequenz CRLF. Wir empfehlen jedoch, dass Anwendungen beim Parsen solcher Header einen einzelnen LF als Zeilenabschluss erkennen und den führenden CR ignorieren.

Im neueren RFC7230 ist § 3.5

Obwohl der Zeilenabschluss für die Startzeilen- und Kopfzeilenfelder die Sequenz CRLF ist, kann ein Empfänger einen einzelnen LF als Zeilenabschluss erkennen und alle vorhergehenden CR ignorieren.

Verwenden Sie daher, es sei denn, Sie möchten böse sein oder auf andere Weise gegen die RFC-Regeln verstoßen \r\n.


@Fred: Nein, es gibt so etwas wie zu offensichtlich - unnötige Wiederholungen und unnötige Wiederholungen und sinnlose Wiederholungen derselben Informationen trüben die Nachricht. Vor allem, wenn das Gleiche oben zitiert wird - nicht weniger aus der Spezifikation.
Piskvor verließ das Gebäude

2
Gute klare Antwort. Genau dafür ist StackOverflow am besten geeignet: einfache, klare Antworten auf einfache, klare Fragen, ohne die unnötige und nicht hilfreiche Unordnung von Blogs und Artikeln.
Miles Rout

@ MilesRout: Danke :)
Piskvor verließ das Gebäude

2
@ Pacerier: Erwähnt so etwas überhaupt nicht; Da im Wesentlichen angegeben wird, dass dies die einzig gültige Syntax für HTTP ist, ist alles andere eine ungültige Syntax. Natürlich könnten Sie den RFC verletzen, was Sie wollen, es gibt niemanden, der Sie aufhalten könnte - aber dann implementieren Sie technisch keinen HTTP-Client mehr, nur etwas, das ähnlich aussieht;)
Piskvor hat das Gebäude

2
RFC7230, das RFC2616 überholt, enthält den gleichen Text in Abschnitt 3.5
Trauer

22

\ r \ n, weil RFC 2616 dies sagt (Abschnitt 2.2, "Grundregeln"):

HTTP / 1.1 definiert die Sequenz CR LF als Zeilenende-Marker für alle
Protokollelemente mit Ausnahme des Entity-Body (
tolerante Anwendungen siehe Anhang 19.3 ). Die Zeilenende-Markierung innerhalb eines Entitätskörpers wird durch den zugehörigen Medientyp definiert, wie in Abschnitt 3.7 beschrieben.

   CRLF           = CR LF

Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.