पायथन - एचटीटीपी हेडर
क्लाइंट और सर्वर के बीच अनुरोध और प्रतिक्रिया में संदेश में हेडर और बॉडी शामिल है। हेडर्स में प्रोटोकॉल विशिष्ट जानकारी होती है जो टीसीपी कनेक्शन पर भेजे गए कच्चे संदेश की शुरुआत में दिखाई देती है। संदेश का मुख्य भाग रिक्त पंक्ति का उपयोग करके शीर्ष लेख से अलग किया जाता है।
हेडर्स का उदाहरण
Http प्रतिक्रिया में शीर्षकों को निम्नलिखित प्रकारों में वर्गीकृत किया जा सकता है। नीचे हेडर का वर्णन और एक उदाहरण है।
कैश-नियंत्रण
कैश-कंट्रोल सामान्य हेडर फ़ील्ड का उपयोग निर्देशों को निर्दिष्ट करने के लिए किया जाता है जो सभी कैशिंग सिस्टम द्वारा पालन किए जाने चाहिए। सिंटैक्स निम्नानुसार है:
Cache-Control : cache-request-directive|cache-response-directive
एक HTTP क्लाइंट या सर्वर का उपयोग कर सकते हैं Cache-controlसामान्य शीर्ष लेख कैश के लिए पैरामीटर निर्दिष्ट करने के लिए या कैश से कुछ प्रकार के दस्तावेज़ों का अनुरोध करने के लिए। कैशिंग निर्देश एक अल्पविराम से अलग की गई सूची में निर्दिष्ट हैं। उदाहरण के लिए:
Cache-control: no-cache
संबंध
कनेक्शन सामान्य-हेडर फ़ील्ड प्रेषक को उन विकल्पों को निर्दिष्ट करने की अनुमति देता है जो उस विशेष कनेक्शन के लिए वांछित हैं और आगे के कनेक्शन पर प्रॉक्सी द्वारा संप्रेषित नहीं किया जाना चाहिए। कनेक्शन हेडर का उपयोग करने के लिए सरल सिंटैक्स निम्नलिखित है:
Connection : "Connection"
HTTP / 1.1 प्रेषक को संकेत के लिए "करीब" कनेक्शन विकल्प को परिभाषित करता है कि प्रतिक्रिया के पूरा होने के बाद कनेक्शन बंद हो जाएगा। उदाहरण के लिए:
Connection: close
डिफ़ॉल्ट रूप से, HTTP 1.1 लगातार कनेक्शन का उपयोग करता है, जहां लेनदेन के बाद कनेक्शन स्वचालित रूप से बंद नहीं होता है। दूसरी ओर, HTTP 1.0, डिफ़ॉल्ट रूप से लगातार कनेक्शन नहीं रखता है। यदि कोई 1.0 क्लाइंट लगातार कनेक्शन का उपयोग करना चाहता है, तो वह इसका उपयोग करता हैkeep-alive पैरामीटर निम्नानुसार है:
Connection: keep-alive
दिनांक
बिना किसी अपवाद के सभी HTTP दिनांक / समय टिकटों को ग्रीनविच मीन टाइम (GMT) में दर्शाया जाना चाहिए। HTTP एप्लिकेशन को दिनांक / समय टिकटों के निम्नलिखित तीन प्रतिनिधित्वों में से किसी का उपयोग करने की अनुमति है:
Sun, 06 Nov 1994 08:49:37 GMT ; RFC 822, updated by RFC 1123
Sunday, 06-Nov-94 08:49:37 GMT ; RFC 850, obsoleted by RFC 1036
Sun Nov 6 08:49:37 1994 ; ANSI C's asctime() format
स्थानांतरण-एन्कोडिंग
स्थानांतरण-एन्कोडिंग सामान्य हेडर फ़ील्ड इंगित करता है क्या परिवर्तन के प्रकार के लिए संदेश के मुख्य भाग को लागू किया गया है सुरक्षित रूप से प्रेषक और प्राप्तकर्ता के बीच यह हस्तांतरण। यह सामग्री-एन्कोडिंग के समान नहीं है क्योंकि हस्तांतरण-एन्कोडिंग संदेश की एक संपत्ति है, इकाई-निकाय की नहीं। ट्रांसफ़र-एन्कोडिंग हेडर फ़ील्ड का सिंटैक्स निम्नानुसार है:
Transfer-Encoding: chunked
सभी स्थानांतरण-कोडिंग मान केस-असंवेदनशील हैं।
अपग्रेड
अपग्रेड सामान्य हेडर क्या अतिरिक्त संचार प्रोटोकॉल का समर्थन करता है निर्दिष्ट करने के लिए ग्राहक और यदि सर्वर पाता यह स्विच प्रोटोकॉल के लिए उचित उपयोग करना चाहते हैं अनुमति देता है। उदाहरण के लिए:
Upgrade: HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11
अपग्रेड हेडर फील्ड का उद्देश्य HTTP / 1.1 से किसी अन्य, असंगत प्रोटोकॉल में संक्रमण के लिए एक सरल तंत्र प्रदान करना है।
के जरिए
के माध्यम से सामान्य हेडर द्वार और प्रॉक्सी द्वारा इस्तेमाल किया जाना चाहिए मध्यवर्ती प्रोटोकॉल और प्राप्तकर्ताओं इंगित करने के लिए। उदाहरण के लिए, एक अनुरोध संदेश एक HTTP / 1.0 उपयोगकर्ता एजेंट से एक आंतरिक प्रॉक्सी कोड-नाम "फ़्रेड" के लिए भेजा जा सकता है, जो HTTP / 1.1 का उपयोग करता है, जो कहीं भी सार्वजनिक.कॉम पर अनुरोध को आगे बढ़ाता है, जो अनुरोध को पूरा करता है www.ics.uci.edu पर इसे मूल सर्वर पर अग्रेषित किया जा रहा है। Www.ics.uci.edu द्वारा प्राप्त अनुरोध के बाद निम्न वाया हैडर फ़ील्ड होगा:
Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)
अपग्रेड हेडर फील्ड का उद्देश्य HTTP / 1.1 से किसी अन्य, असंगत प्रोटोकॉल में संक्रमण के लिए एक सरल तंत्र प्रदान करना है।
चेतावनी
चेतावनी सामान्य हैडर स्थिति या संदेश जो संदेश में प्रदर्शित नहीं किया जा सकता के परिवर्तन के बारे में अतिरिक्त जानकारी ले जाने के लिए प्रयोग किया जाता है। प्रतिक्रिया में एक से अधिक चेतावनी शीर्षक हो सकते हैं।
Warning : warn-code SP warn-agent SP warn-text SP warn-date
उदाहरण
नीचे दिए गए उदाहरण में हम urliben का उपयोग करके प्रतिक्रिया प्राप्त करने के लिए urllib2 मॉड्यूल का उपयोग करते हैं। आगे हम उस प्रतिक्रिया के लिए हेडर की जानकारी प्राप्त करने के लिए जानकारी () विधि लागू करते हैं।
import urllib2
response = urllib2.urlopen('http://www.tutorialspoint.com/python')
html = response.info()
print html
जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्नलिखित आउटपुट मिलते हैं -
Access-Control-Allow-Headers: X-Requested-With
Access-Control-Allow-Origin: *
Cache-Control: max-age=2592000
Content-Type: text/html; charset=UTF-8
Date: Mon, 02 Jul 2018 11:06:07 GMT
Expires: Wed, 01 Aug 2018 11:06:07 GMT
Last-Modified: Sun, 01 Jul 2018 21:05:38 GMT
Server: ECS (tir/CDD1)
Vary: Accept-Encoding
X-Cache: HIT
Content-Length: 22063
Connection: close