🎯 कस्टमाइज़ करने योग्य, डिटेक्शन-प्रतिरोधी क्लाउड ब्राउज़र जो स्व-विकसित Chromium द्वारा संचालित है, वेब क्रॉलर और एआई एजेंट्स के लिए डिज़ाइन किया गया। 👉अभी आज़माएं
वापस ब्लॉग पर

cURL के साथ HTTP हेडर कैसे भेजें: एक व्यापक मार्गदर्शिका

Michael Lee
Michael Lee

Expert Network Defense Engineer

22-Sep-2025

मुख्य निष्कर्ष:

  • HTTP हेडर क्लाइंट-सर्वर संचार के लिए महत्वपूर्ण हैं, जो अनुरोधों और प्रतिक्रियाओं के बारे में आवश्यक मेटाडेटा संप्रेषित करते हैं।
  • cURL -H या --header विकल्प प्रदान करता है जिससे आप अपने अनुरोधों के साथ कस्टम HTTP हेडर आसानी से भेज सकते हैं।
  • आप -H विकल्प का कई बार उपयोग करके कई हेडर भेज सकते हैं।
  • हेडरों को समझना और उनका हेरफेर करना वेब स्क्रैपिंग, एपीआई परीक्षण और नेटवर्क मुद्दों को डिबग करने के लिए महत्वपूर्ण है।
  • cURL के साथ प्रतिक्रिया हेडर देखना डिबगिंग और सर्वर के व्यवहार को समझने में मदद करता है।

परिचय

cURL (क्लाइंट यूआरएल) डेटा को यूआरएल के साथ स्थानांतरित करने के लिए एक शक्तिशाली कमांड-लाइन उपकरण है, जो HTTP, HTTPS और FTP जैसे प्रोटोकॉल का समर्थन करता है। डेवलपर्स और सिस्टम प्रशासकों के लिए, cURL अपरिहार्य है। HTTP हेडर भेजने और प्राप्त करने की इसकी क्षमता क्लाइंट-सर्वर इंटरैक्शन को परिभाषित करने के लिए मौलिक है। यह गाइड cURL के साथ HTTP हेडर भेजने के तरीके का एक व्यापक अवलोकन प्रदान करता है, जिसमें विभिन्न परिदृश्य, व्यावहारिक उदाहरण और सर्वश्रेष्ठ प्रथाएँ शामिल हैं।

HTTP हेडर क्या हैं?

HTTP हेडर HTTP अनुरोधों और प्रतिक्रियाओं का एक मौलिक हिस्सा हैं, जो लेनदेन के बारे में आवश्यक मेटाडेटा ले जाते हैं। वे एक पत्र के लिए लिफाफा और डाक जानकारी के रूप में कार्य करते हैं, जबकि शरीर स्वयं पत्र है। वे कैशिंग, प्रमाणीकरण और सामग्री बातचीत जैसी सुविधाओं की अनुमति देते हैं।

HTTP हेडरों के प्रकार:

  • अनुरोध हेडर: क्लाइंट द्वारा भेजे गए (जैसे, User-Agent, Authorization)।
  • प्रतिक्रिया हेडर: सर्वर द्वारा भेजे गए (जैसे, Content-Type, Set-Cookie)।
  • सामान्य हेडर: दोनों पर लागू होते हैं (जैसे, Date, Connection)।
  • एंटिटी हेडर: शरीर का वर्णन करते हैं (जैसे, Content-Length)।

अनुरोध हेडर में हेरफेर करना डिबगिंग, एपीआई परीक्षण, और विशिष्ट क्लाइंट व्यवहारों की नकल करने के लिए महत्वपूर्ण है।

बुनियादी सिंटैक्स: एकल हेडर भेजना

cURL के साथ HTTP हेडर भेजने के लिए, -H या --header विकल्प का उपयोग करें, इसके बाद "Header-Name: Header-Value" लिखा जाए।

सिंटैक्स:

bash Copy
curl -H "Header-Name: Header-Value" [URL]

उदाहरण 1: कस्टम यूजर-एजेंट सेट करना

cURL के डिफ़ॉल्ट User-Agent को ओवरराइड करें ताकि यह एक वेब ब्राउज़र की नकल कर सके:

bash Copy
curl -H "User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36" https://www.example.com

यह अनुरोध को Chrome ब्राउज़र से उत्पन्न दिखाता है, जो उन वेबसाइटों के साथ बातचीत के लिए उपयोगी है जो गैर-ब्राउज़र यूजर एजेंट को रोकती हैं।

उदाहरण 2: स्वीकार हेडर सेट करना

पसंदीदा सामग्री प्रकार, जैसे JSON, निर्दिष्ट करें:

bash Copy
curl -H "Accept: application/json" https://api.example.com/data

यह API अंत बिंदु से JSON प्रारूप में डेटा का अनुरोध करता है।

कई HTTP हेडर भेजना

एकल आदेश में कई हेडर भेजने के लिए, -H विकल्प का कई बार उपयोग करें।

सिंटैक्स:

bash Copy
curl -H "Header-Name-1: Header-Value-1" \
     -H "Header-Name-2: Header-Value-2" \
     [URL]

उदाहरण 3: प्रमाणीकरण और सामग्री प्रकार के साथ POST अनुरोध

API कॉल के लिए Authorization और Content-Type हेडर शामिल करें:

bash Copy
curl -X POST \
     -H "Content-Type: application/json" \
     -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \
     -d '{"name": "John Doe", "age": 30}' \
     https://api.example.com/users

यह JSON डेटा के साथ एक POST अनुरोध भेजता है, जो एक बियरर टोकन द्वारा प्रमाणीकरण किया जाता है।

डिफ़ॉल्ट हेडर ओवरराइड करना

cURL कुछ डिफ़ॉल्ट हेडर भेजता है। उन्हें ओवरराइड करने के लिए अपने कस्टम मान को -H के साथ निर्दिष्ट करें। आपका कस्टम हेडर प्राथमिकता लेगा।

उदाहरण 4: यूजर-एजेंट हेडर ओवरराइड करना

bash Copy
curl -H "User-Agent: MyCustomApp/1.0" https://www.example.com

यह आपके क्लाइंट को सर्वर पर MyCustomApp/1.0 के रूप में पहचानता है।

उदाहरण 5: डिफ़ॉल्ट हेडर हटाना

ऐसे हेडर को हटाने के लिए जिसे cURL सामान्यतः भेजता है, बिना मान के सेमीकॉलन का उपयोग करें:

bash Copy
curl -H "Accept-Encoding;" https://www.example.com

यह स्पष्ट रूप से cURL को Accept-Encoding हेडर भेजने से रोकता है।

विभिन्न HTTP विधियों के साथ हेडर भेजना

cURL सभी मानक HTTP विधियों का समर्थन करता है, -X विकल्प का उपयोग करके, जिसमें हेडर -H के माध्यम से जोड़े जाते हैं।

उदाहरण 6: हेडर्स के साथ PUT अनुरोध

bash Copy
curl -X PUT \
     -H "Content-Type: application/json" \
     -H "Authorization: Bearer YOUR_AUTH_TOKEN" \
     -d '{"status": "active"}' \
     https://api.example.com/items/123

यह एक संसाधन को अपडेट करता है, सुनिश्चित करता है कि सामग्री की सही व्याख्या और प्रमाणीकरण हो।

उदाहरण 7: हेडर्स के साथ DELETE अनुरोध

bash Copy
curl -X DELETE \
     -H "Authorization: Bearer YOUR_AUTH_TOKEN" \
     https://api.example.com/items/456

यह एक संसाधन के लिए प्रमाणीकरण प्राप्त DELETE अनुरोध को निष्पादित करता है।

cURL के साथ कुकीज़ प्रबंधित करना

कुकीज़ चरण प्रबंधन के लिए विशेष HTTP हेडर हैं। cURL उन्हें भेजने और प्राप्त करने के लिए विशिष्ट विकल्प प्रदान करता है।

उदाहरण 8: कुकी भेजना

-H "Cookie: ..." या अधिक सुविधाजनक -b (या --cookie) विकल्प का उपयोग करें:

bash Copy
curl -b "session_id=abc123xyz" https://www.example.com/dashboard

उदाहरण 9: एक फ़ाइल से कुकीज़ सहेजना और भेजना
पहले, सर्वर से प्राप्त कुकीज़ को cookies.txt में सहेजें:

bash Copy
curl -c cookies.txt https://www.example.com/login

फिर, इन कुकीज़ को Subsequent अनुरोधों में भेजें:

bash Copy
curl -b cookies.txt https://www.example.com/profile

यह लॉगिन किए गए उपयोगकर्ता सत्रों का अनुकरण करने के लिए मूलभूत है।

प्रतिक्रिया हेडर्स को देखना

प्रतिक्रिया हेडर्स को देखना डिबगिंग और सर्वर के व्यवहार को समझने के लिए महत्वपूर्ण है। -i या -I का उपयोग करें।

उदाहरण 10: सभी प्रतिक्रिया हेडर्स और बॉडी को देखना

हेडर्स और प्रतिक्रिया बॉडी दोनों को प्रदर्शित करने के लिए -i (या --include) का उपयोग करें:

bash Copy
curl -i https://www.example.com

उदाहरण 11: केवल प्रतिक्रिया हेडर्स को देखना (HEAD अनुरोध)

केवल हेडर्स प्राप्त करने के लिए -I (या --head) का उपयोग करें, बिना बॉडी के:

bash Copy
curl -I https://www.example.com

यह संसाधन की स्थिति या कैशिंग हेडर्स की जांच करने के लिए कुशल है।

उदाहरण 12: हेडर्स को फ़ाइल में सहेजना

प्रतिक्रिया हेडर्स को फ़ाइल में सहेजने के लिए -D या --dump-header का उपयोग करें:

bash Copy
curl -D headers.txt https://www.example.com

यह हेडर्स को headers.txt में सहेजता है जबकि बॉडी को मानक आउटपुट पर प्रिंट करता है।

cURL के साथ HTTP हेडर्स भेजने के व्यावहारिक उपयोग के मामले

कस्टम हेडर्स विभिन्न अनुप्रयोगों के लिए अनिवार्य हैं:

1. API परीक्षण और डिबगिंग

API एंडपॉइंट्स का परीक्षण करने के लिए प्रमाणीकरण या कस्टम पैरामीटर के लिए विशिष्ट हेडर्स भेजें।

उदाहरण: X-API-Key के साथ API का परीक्षण करना।

bash Copy
curl -H "X-API-Key: your_secret_api_key" https://api.example.com/v1/data

2. वेब स्क्रैपिंग और डेटा निष्कर्षण

सुनिश्चित करने के लिए कि कोई पहचान न सके, User-Agent, Referer, और Cookie हेडर्स सेट करके असली ब्राउज़र की नकल करें।

उदाहरण: ब्राउज़र-जैसे User-Agent और सत्र कुकी के साथ स्क्रैपिंग।

bash Copy
curl -H "User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36" \
     -b "session_id=your_session_id" \
     https://www.example.com/protected_data

3. ब्राउज़र व्यवहार का अनुकरण करना

फार्म सबमिशन जैसे इंटरैक्शन का अनुकरण करें, जहाँ हेडर्स महत्वपूर्ण भूमिका निभाते हैं।

उदाहरण: application/x-www-form-urlencoded के साथ फार्म सबमिशन का अनुकरण करना।

bash Copy
curl -X POST \
     -H "Content-Type: application/x-www-form-urlencoded" \
     -d "username=testuser&password=testpass" \
     https://www.example.com/login

4. वेब सर्वर कॉन्फ़िगरेशन का परीक्षण

सर्वर कॉन्फ़िगरेशन, कैशिंग नीतियों और सुरक्षा सेटिंग्स का परीक्षण करें।

उदाहरण: If-Modified-Since के साथ कैशिंग व्यवहार की जांच करना।

bash Copy
curl -I -H "If-Modified-Since: Wed, 21 Oct 2015 07:28:00 GMT" https://www.example.com/static/image.jpg

सर्वश्रेष्ठ प्रथाएं और समस्या निवारण

cURL के साथ HTTP हेडर्स का प्रभावी और जिम्मेदार उपयोग सुनिश्चित करने के लिए, इन सर्वोत्तम प्रथाओं और समस्या निवारण सुझावों पर विचार करें:

सर्वोत्तम प्रथाएं:

  • विशिष्ट रहें: केवल आवश्यक हेडर्स भेजें। अत्यधिक हेडर्स एंटी-बॉट तंत्र को सक्रिय कर सकते हैं।
  • User-Agent का बुद्धिमानी से उपयोग करें: वेब स्क्रैपिंग के लिए एक लोकप्रिय ब्राउज़र की नकल करें ताकि अवरुद्ध न हों, लेकिन लक्षित बोट पहचान के प्रति जागरूक रहें।
  • कुकीज़ को सही ढंग से संभालें: सत्र प्रबंधन के लिए -c (cookie-jar) और -b (cookie) विकल्पों का उपयोग करें, न कि मैन्युअल Cookie हेडर्स।
  • प्रतिक्रियाओं का निरीक्षण करें: डिबगिंग और सर्वर के व्यवहार को समझने के लिए हमेशा -i या -I का उपयोग करें।
  • URL एन्कोड करें: विशेष चरित्रों के साथ समस्याओं को रोकने के लिए क्वेरी स्ट्रिंग्स या फॉर्म डेटा में पैरामीटर को सही ढंग से URL-एन्कोड करें।
  • robots.txt का सम्मान करें: नैतिक रूप से, स्वचालित कार्यों के लिए एक वेबसाइट के robots.txt दिशानिर्देशों की जांच करें और उनका पालन करें।

सामान्य मुद्दों को हल करना:

  • "403 Forbidden" या "401 Unauthorized" त्रुटियाँ:
    • Authorization हेडर (टोकन की वैधता) की पुष्टि करें।
    • User-Agent और Referer हेडर्स की जांच करें।
    • आईपी ब्लॉकिंग पर विचार करें; प्रॉक्सी का उपयोग करें या प्रतीक्षा करें।
  • गलत सामग्री या खाली प्रतिक्रियाएँ:
    • सुनिश्चित करें कि Content-Type और Accept हेडर्स सर्वर अपेक्षाओं से मेल खाते हैं।
    • जावास्क्रिप्ट रेंडरिंग: cURL कच्चा HTML लाता है। यदि सामग्री JS-रेंडर की गई है, तो हेडलेस ब्राउज़र या विशेष स्क्रैपिंग एपीआई पर विचार करें।
    • Redirects का पालन करें: HTTP 3xx redirects का अनुसरण करने के लिए -L या --location का उपयोग करें।
  • संযোগ टाइमआउट या कनेक्शन अस्वीकृत:
    • सुनिश्चित करें कि URL सही है और सर्वर पहुँच योग्य है।
    • स्थानीय फ़ायरवॉल या नेटवर्क प्रॉक्सी की जांच करें।
    • सर्वर अस्थायी रूप से डाउन या अधिक लोड हो सकता है।

cURL में विस्तृत आउटपुट (-v) विकल्प का उपयोग डिबगिंग के लिए अनमोल विस्तृत जानकारी प्रदान कर सकता है।

निष्कर्ष और कार्रवाई के लिए कॉल

HTTP हेडर्स के साथ cURL भेजना किसी भी व्यक्ति के लिए एक मौलिक कौशल है जो वेब प्रौद्योगिकियों के साथ काम कर रहा है। प्रारंभिक User-Agent हेरफेर से लेकर जटिल प्रमाणीकरण योजनाओं और कुकी प्रबंधन तक, cURL सटीक HTTP अनुरोध बनाने की लचीलापन और शक्ति प्रदान करता है। इन तकनीकों में महारत हासिल करना प्रभावी API परीक्षण, मजबूत वेब स्क्रैपिंग और Thorough नेटवर्क डिबगिंग के लिए आवश्यक है।
यहां हर हेडर की भूमिका को समझने और cURL के विविध विकल्पों का उपयोग करके, आप अपने क्लाइंट-सर्वर इंटरैक्शन पर अधिक नियंत्रण प्राप्त कर सकते हैं। हमेशा सर्वोत्तम प्रथाओं का पालन करना, वेबसाइट नीतियों का सम्मान करना और cURL की डिबगिंग सुविधाओं का लाभ उठाना याद रखें ताकि आपकी अनुरोध प्रभावी और जिम्मेदार दोनों हों।

क्या आप अपने cURL कौशल को बढ़ाने के लिए तैयार हैं?

इस गाइड में प्रदान किए गए उदाहरणों के साथ प्रयोग करें, cURL की व्यापक दस्तावेज़ीकरण का अन्वेषण करें, और इन तकनीकों को अपने दैनिक कार्यप्रवाह में समाहित करें। HTTP हेडर को सटीक रूप से नियंत्रित करने की क्षमता निश्चित रूप से आपको एक अधिक प्रभावी और सक्षम वेब पेशेवर बना देगी।

अक्सर पूछे जाने वाले प्रश्न (FAQ)

प्रश्न 1: -H और -b में हेडर भेजने के लिए क्या अंतर है?

-H (या --header) किसी भी कस्टम HTTP हेडर को "हेडर-नाम: हेडर-मूल्य" प्रारूप में भेजने के लिए एक सामान्य उद्देश्य विकल्प है। -b (या --cookie) विशेष रूप से कुकी भेजने के लिए है, जब भी आप केवल कुकीज़ के साथ काम करते हैं, तो यह अधिक सुविधाजनक होता है, खासकर जब इसे एक फ़ाइल से किया जाए।

प्रश्न 2: मैं कैसे देख सकता हूँ कि cURL डिफ़ॉल्ट रूप से कौन से सभी हेडर भेजता है?

अपने cURL कमांड के साथ -v (या --verbose) विकल्प का उपयोग करें। यह विस्तृत आउटपुट प्रदान करता है, जिसमें पूरा अनुरोध शामिल है जो cURL भेजता है (सभी डिफ़ॉल्ट हेडर के साथ), कनेक्शन प्रक्रिया और सर्वर की पूरी प्रतिक्रिया।

प्रश्न 3: क्या cURL HTTP/2 या HTTP/3 हेडर संभाल सकता है?

हाँ, cURL HTTP/2 और HTTP/3 (QUIC) का समर्थन करता है। यह अक्सर इन प्रोटोकॉल का उपयोग करने के लिए स्वचालित रूप से बातचीत करता है। हेडर निर्दिष्ट करने के लिए -H विकल्प समान रहता है, क्योंकि cURL आंतरिक रूप से प्रोटोकॉल-विशिष्ट प्रारूपण को संभालता है।

प्रश्न 4: मैं खाली मूल्य के साथ एक हेडर कैसे भेजूँ?

खाली मूल्य के साथ एक हेडर भेजने के लिए, इसे "हेडर-नाम:" (एक कोलन के साथ लेकिन कोई मूल्य नहीं) के रूप में निर्दिष्ट करें। उस हेडर को हटाने के लिए जिसे cURL सामान्य रूप से भेजेगा, "हेडर-नाम;" (एक सेमीकोलन के साथ) का उपयोग करें, जो cURL को पूरी तरह से उस हेडर को दबाने के लिए बताता है।

प्रश्न 5: क्या हेडरों में गैर-ASCII वर्ण भेजना संभव है?

HTTP हेडर पारंपरिक रूप से केवल ASCII होते हैं। गैर-ASCII वर्णों को URL-कोडित या Base64-कोडित किया जाना चाहिए, यह हेडर और इसके उपयोग पर निर्भर करता है। अधिकांश सामान्य मामलों के लिए, हेडर मूल्यों में संगतता के लिए ASCII का पालन करना अनुशंसित है।

स्क्रैपलेस में, हम केवल सार्वजनिक रूप से उपलब्ध डेटा का उपयोग करते हैं, जबकि लागू कानूनों, विनियमों और वेबसाइट गोपनीयता नीतियों का सख्ती से अनुपालन करते हैं। इस ब्लॉग में सामग्री केवल प्रदर्शन उद्देश्यों के लिए है और इसमें कोई अवैध या उल्लंघन करने वाली गतिविधियों को शामिल नहीं किया गया है। हम इस ब्लॉग या तृतीय-पक्ष लिंक से जानकारी के उपयोग के लिए सभी देयता को कोई गारंटी नहीं देते हैं और सभी देयता का खुलासा करते हैं। किसी भी स्क्रैपिंग गतिविधियों में संलग्न होने से पहले, अपने कानूनी सलाहकार से परामर्श करें और लक्ष्य वेबसाइट की सेवा की शर्तों की समीक्षा करें या आवश्यक अनुमतियाँ प्राप्त करें।

सबसे लोकप्रिय लेख

सूची