`कर्ल -I` और` कर्ल -X HEAD` के बीच अंतर


70

मैं से हास्यास्पद सर्वर प्रकार देख रहा था http://www.reddit.com साथ curl -I http://www.reddit.comजब मैं अनुमान लगाया है कि curl -X HEAD http://www.reddit.comएक ही करना होगा। लेकिन, वास्तव में, यह नहीं है।

मैं क्यों के बारे में उत्सुक हूँ।

यह वही है जो मैं दो आज्ञाओं का पालन करता हूं:

  • curl -I: अपेक्षित रूप से काम करता है, हेडर को आउटपुट करता है और मौजूद होता है।

  • curl -X HEAD: कुछ भी नहीं दिखाता है और उपयोगकर्ता इनपुट की प्रतीक्षा करता है।

लेकिन, tsharkमैं दूसरी कमांड को वास्तव में उसी HTML क्वेरी भेजता है और सही उत्तर प्राप्त करता है , के साथ सूँघता है , लेकिन यह इसे नहीं दिखाता है और यह कनेक्शन बंद नहीं करता है।

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

व्यवहार में इस अंतर के बारे में कोई विचार क्यों?


जवाबों:


66

ऐसा लगता है कि अंतर का Content-Lengthहेडर के साथ क्या करना है और यह दोनों कमांड द्वारा कैसे व्यवहार किया जाता है।

लेकिन इसमें जाने से पहले, curl -X HEADकोई आउटपुट नहीं देता है, क्योंकि डिफ़ॉल्ट रूप से, curlहेडर प्रिंट नहीं करता है यदि स्विच -iप्रदान नहीं किया जाता है ( -Iहालांकि इसकी आवश्यकता नहीं है )।

किसी भी मामले में, curl -Iहेडर लाने के लिए उचित तरीका है। यह सिर्फ हेडर के लिए पूछता है और कनेक्शन बंद कर देता है।

दूसरी ओर curl -X HEAD -iद्वारा बताई गई बाइट्स की संख्या के प्रसारण के लिए इंतजार करना होगा Content-Length। मामले में कोई Content-Lengthनिर्दिष्ट नहीं है, मुझे लगता है कि यह कुछ डेटा या उस विशेष हेडर के लिए इंतजार करेगा।

इस व्यवहार को दिखाने वाले कुछ उदाहरण:

$ curl -X HEAD -i http://www.elpais.es
HTTP/1.1 301 Moved Permanently
Server: AkamaiGHost
Content-Length: 0
Location: http://www.elpais.com/
Date: Wed, 12 May 2010 06:35:57 GMT
Connection: keep-alive

क्योंकि Content-Length0 है, इस स्थिति में दोनों कमांड एक जैसा व्यवहार करते हैं। और बाद में कनेक्शन बंद कर दिया जाता है।

$ curl -X HEAD -i http://slashdot.org
HTTP/1.1 200 OK
Server: Apache/1.3.41 (Unix) mod_perl/1.31-rc4
SLASH_LOG_DATA: shtml
X-Powered-By: Slash 2.005001296
X-Bender: Since I love you all so much, I'd like to give everyone hugs.
X-XRDS-Location: http://slashdot.org/slashdot.xrds
Cache-Control: no-cache
Pragma: no-cache
Content-Type: text/html; charset=iso-8859-1
Content-Length: 115224
Date: Wed, 12 May 2010 06:37:20 GMT
X-Varnish: 1649060825 1649060810
Age: 1
Connection: keep-alive

curl: (18) transfer closed with 115224 bytes remaining to read

इस मामले में, एक टाइमआउट (शायद वार्निश द्वारा) प्रतीत होता है, इसलिए curlविरोध करता है कि Content-Lengthबाइट्स की संख्या प्राप्त करने से पहले कनेक्शन बंद कर दिया गया था ।

वैसे, मज़ेदार एक्स-बेंडर (उदाहरण में दिखाए गए) और एक्स-फ्राई (खुद के लिए प्रयास करें) हेडर :) देखें।


2
यदि कोई अन्य व्यक्ति इसकी तलाश में आता है: PHP के कर्ल लाइब्रेरी में सेट करने का विकल्प है CURLOPT_NOBODY
मत्ती

12

मुझे लगता है कि यह कर्ल में एक बग है। यदि मैं -X के साथ एक विधि निर्दिष्ट करता हूं, तो कर्ल को RFC के अनुसार प्रतिक्रिया को संभालना चाहिए। दुर्भाग्य से, कर्ल का अनुचर सहमत नहीं है। किसी ने एक बग दर्ज किया और यहां तक ​​कि एक पैच प्रस्तुत किया:

http://sourceforge.net/tracker/?func=detail&atid=100976&aid=1810273&group_id=976

लेकिन कर्ल मेंटेनर ने इसे अस्वीकार कर दिया। जाहिरा तौर पर एक टूटा हुआ "-X HEAD" विकल्प "डिज़ाइन के अनुसार काम करना" है।

--Jamshid


4
निष्पक्ष होने के लिए, मैं टिकट प्रतिक्रिया के तर्क का पालन कर सकता हूं: --headहमें एक HEAD अनुरोध के वैध कार्यान्वयन के साथ प्रदान करता है, और अनुरोध में -X <method>केवल HTTP पद्धति को ओवरराइड करता है।
हांक

3
हाँ, यह वास्तव में मुझे क्या चाहिए था। मेरे पास एक छोटी गाड़ी है जो HEAD रिक्वेस्ट दिए जाने पर कंटेंट सर्व करती है। -X HEADजब मैं RFC का पालन करने के लिए सर्वर प्राप्त करने की कोशिश कर रहा था, तो मैं इसे एकमात्र तरीका था
हैशब्रोएन

5

से डॉक्स :

-X, - क्रेस्ट

(HTTP) HTTP सर्वर के साथ संचार करते समय उपयोग करने के लिए एक कस्टम अनुरोध विधि निर्दिष्ट करता है। निर्दिष्ट अनुरोध विधि का उपयोग विधि के बजाय किया जाएगा अन्यथा उपयोग किया जाता है (जो कि जीईटी में चूक करता है)। विवरण और स्पष्टीकरण के लिए HTTP 1.1 विनिर्देश पढ़ें। सामान्य अतिरिक्त HTTP अनुरोधों में PUT और DELETE शामिल हैं, लेकिन WebDAV जैसी संबंधित तकनीकें PROPFIND, COPY, MOVE और बहुत कुछ प्रदान करती हैं।

आम तौर पर आपको इस विकल्प की आवश्यकता नहीं होती है। GET, HEAD, POST और PUT अनुरोधों के सभी प्रकार समर्पित कमांड लाइन विकल्पों का उपयोग करके लागू किए जाते हैं।

यह विकल्प केवल HTTP अनुरोध में उपयोग किए जाने वाले वास्तविक शब्द को बदलता है , यह कर्ल के व्यवहार के तरीके को नहीं बदलता है । इसलिए उदाहरण के लिए यदि आप एक उचित HEAD अनुरोध करना चाहते हैं, तो -X HEAD का उपयोग करना पर्याप्त नहीं होगा। आपको -I, --head विकल्प का उपयोग करना होगा।

दूसरे शब्दों में, -Xके अलावा अन्य तरीकों के लिए है GET, HEAD, POSTऔर PUTHEADउपयोग के लिए -I


0

मैं एक ही मुद्दे पर मिलते हैं जब कर्ल पर cpp कोड लिखता है 7.34,

curl_easy_setopt(curl_handle, CURLOPT_CUSTOMREQUEST, "HEAD");

वहाँ एक लंबा समय लटका होगा, ऐसा लगता है कि यह बॉडी ट्रांसफ़र का इंतज़ार कर रहा है जब तक कि टाइमआउट नहीं हो जाता। नई लाइन जोड़ने के बाद, यह समस्या हल हो गई है।

curl_easy_setopt(curl_handle, CURLOPT_NOBODY, 1L );

से दस्तावेज़

शरीर को प्राप्त किए बिना डाउनलोड अनुरोध करें

यह रेखा कर्ल को प्रतीक्षा न करने के लिए मजबूर करेगी।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.