Ich habe den lustigen Servertyp von http://www.reddit.com mit angesehen, curl -I http://www.reddit.com
als ich vermutete, dass dies auch so sein curl -X HEAD http://www.reddit.com
würde. Tatsächlich aber nicht.
Ich bin gespannt warum.
Folgendes beobachte ich beim Ausführen der beiden Befehle:
curl -I
: funktioniert wie erwartet, gibt den Header aus und existiert.curl -X HEAD
: zeigt nichts an und scheint auf Benutzereingaben zu warten.
Beim Schnüffeln mit wird tshark
angezeigt, dass der zweite Befehl tatsächlich dieselbe HTML-Abfrage sendet und die richtige Antwort empfängt, diese jedoch nicht anzeigt und die Verbindung nicht schließt.
curl -I
0.000000 333.33.33.33 -> 213.248.111.106 TCP 59675 > http [SYN] Seq=0 Win=5840 Len=0 MSS=1460 TSV=47267342 TSER=0 WS=6
0.045392 213.248.111.106 -> 333.33.33.33 TCP http > 59675 [SYN, ACK] Seq=0 Ack=1 Win=5792 Len=0 MSS=1460 TSV=2552532839 TSER=47267342 WS=1
0.045441 333.33.33.33 -> 213.248.111.106 TCP 59675 > http [ACK] Seq=1 Ack=1 Win=5888 Len=0 TSV=47267353 TSER=2552532839
0.045623 333.33.33.33 -> 213.248.111.106 HTTP HEAD / HTTP/1.1
0.091665 213.248.111.106 -> 333.33.33.33 TCP http > 59675 [ACK] Seq=1 Ack=155 Win=6432 Len=0 TSV=2552532886 TSER=47267353
0.861782 213.248.111.106 -> 333.33.33.33 HTTP HTTP/1.1 200 OK
0.861830 333.33.33.33 -> 213.248.111.106 TCP 59675 > http [ACK] Seq=155 Ack=321 Win=6912 Len=0 TSV=47267557 TSER=2552533656
0.862127 333.33.33.33 -> 213.248.111.106 TCP 59675 > http [FIN, ACK] Seq=155 Ack=321 Win=6912 Len=0 TSV=47267557 TSER=2552533656
0.910810 213.248.111.106 -> 333.33.33.33 TCP http > 59675 [FIN, ACK] Seq=321 Ack=156 Win=6432 Len=0 TSV=2552533705 TSER=47267557
0.910880 333.33.33.33 -> 213.248.111.106 TCP 59675 > http [ACK] Seq=156 Ack=322 Win=6912 Len=0 TSV=47267570 TSER=2552533705
curl -X HEAD
34.106389 333.33.33.33 -> 213.248.111.90 TCP 51690 > http [SYN] Seq=0 Win=5840 Len=0 MSS=1460 TSV=47275868 TSER=0 WS=6
34.149507 213.248.111.90 -> 333.33.33.33 TCP http > 51690 [SYN, ACK] Seq=0 Ack=1 Win=5792 Len=0 MSS=1460 TSV=3920268348 TSER=47275868 WS=1
34.149560 333.33.33.33 -> 213.248.111.90 TCP 51690 > http [ACK] Seq=1 Ack=1 Win=5888 Len=0 TSV=47275879 TSER=3920268348
34.149646 333.33.33.33 -> 213.248.111.90 HTTP HEAD / HTTP/1.1
34.191484 213.248.111.90 -> 333.33.33.33 TCP http > 51690 [ACK] Seq=1 Ack=155 Win=6432 Len=0 TSV=3920268390 TSER=47275879
34.192657 213.248.111.90 -> 333.33.33.33 TCP [TCP Dup ACK 15#1] http > 51690 [ACK] Seq=1 Ack=155 Win=6432 Len=0 TSV=3920268390 TSER=47275879
34.823399 213.248.111.90 -> 333.33.33.33 HTTP HTTP/1.1 200 OK
34.823453 333.33.33.33 -> 213.248.111.90 TCP 51690 > http [ACK] Seq=155 Ack=321 Win=6912 Len=0 TSV=47276048 TSER=3920269022
Irgendeine Idee, warum dieser Unterschied im Verhalten?
curl
http-headers
diff
chmeee
quelle
quelle
Antworten:
Es scheint, dass der Unterschied mit dem
Content-Length
Header zusammenhängt und wie er von beiden Befehlen behandelt wird.Vorher wird
curl -X HEAD
jedoch keine Ausgabe ausgegeben, da standardmäßigcurl
keine Header gedruckt werden, wenn der Schalter-i
nicht angegeben ist (wird jedoch nicht benötigt-I
).In jedem Fall
curl -I
ist der richtige Weg, um die Header abzurufen. Es fragt nur nach dem Header und schließt die Verbindung.Auf der anderen Seite
curl -X HEAD -i
wird auf die Übertragung der von angegebenen Anzahl von Bytes gewartetContent-Length
. Wenn noContent-Length
nicht angegeben ist, wird es wahrscheinlich auf einige Daten oder auf diesen bestimmten Header warten.Einige Beispiele, die dieses Verhalten zeigen:
Da
Content-Length
0 ist, verhalten sich in diesem Fall beide Befehle gleich. Und die Verbindung wird danach geschlossen.In diesem Fall scheint es eine Zeitüberschreitung zu geben (wahrscheinlich von Varnish), weshalb
curl
protestiert wird, dass die Verbindung geschlossen wurde, bevor dieContent-Length
Anzahl der Bytes empfangen wurde .Schauen Sie sich im Übrigen die lustigen X-Bender- (siehe Beispiel) und X-Fry-Header (probieren Sie es selbst aus) an :).
quelle
CURLOPT_NOBODY
.Ich denke das ist ein Bug in Curl. Wenn ich mit -X eine Methode spezifiziere, sollte curl die Antwort gemäß RFC behandeln. Leider ist der Betreuer von Curl nicht einverstanden. Jemand hat einen Fehler gemeldet und sogar einen Patch eingereicht:
http://sourceforge.net/tracker/?func=detail&atid=100976&aid=1810273&group_id=976
aber der Curl-Betreuer lehnte es ab. Anscheinend funktioniert eine kaputte "-X HEAD" -Option "wie geplant".
- Jamshid
quelle
--head
Versieht uns mit einer gültigen Implementierung einer HEAD-Anfrage und-X <method>
überschreibt einfach die HTTP-Methode in der Anfrage.-X HEAD
Nur so konnte ich es testen, als ich versuchte, den Server dazu zu bringen, sich an den RFC zu haltenAus den Dokumenten :
Mit anderen Worten,
-X
ist für andere Verfahren alsGET
,HEAD
,POST
undPUT
. ZurHEAD
Verwendung-I
.quelle
Ich treffe das gleiche Problem beim Schreiben von CPP-Code auf Curl 7.34,
wird dort eine lange Zeit hängen, scheint es auf Körperübertragung zu warten, bis eine Auszeit eintritt. Nach dem Hinzufügen einer neuen Zeile ist das Problem behoben.
aus dem doc
Diese Linie würde die Locke zwingen, nicht zu warten.
quelle