अनुरोध - त्वरित गाइड

अनुरोध एक HTTP पुस्तकालय है जो आपके वेब एप्लिकेशन में http अनुरोध / प्रतिक्रिया से निपटने के लिए आसान कार्यक्षमता प्रदान करता है। पुस्तकालय अजगर में विकसित किया गया है।

पायथन अनुरोधों की आधिकारिक वेबसाइट जो उपलब्ध है https://2.python-requests.org/en/master/ अनुरोधों को निम्नानुसार परिभाषित करता है -

अनुरोध मानव के लिए बनाया गया पायथन के लिए एक सुरुचिपूर्ण और सरल HTTP पुस्तकालय है।

अनुरोधों की विशेषताएं

अनुरोधों की विशेषताएं नीचे चर्चा की गई हैं -

निवेदन

अजगर अनुरोध पुस्तकालय Http अनुरोध को संभालने के लिए उपलब्ध तरीकों का उपयोग करने के लिए आसान है। मापदंडों को पास करना और GET, POST, PUT, DELETE, आदि जैसे अनुरोध प्रकार को संभालना बहुत आसान है।

प्रतिक्रिया

आपको उस प्रारूप में प्रतिक्रिया मिल सकती है जिसकी आपको आवश्यकता है और समर्थित पाठ प्रारूप, द्विआधारी प्रतिक्रिया, json प्रतिक्रिया और कच्ची प्रतिक्रिया है।

हेडर

पुस्तकालय आपको अपनी आवश्यकताओं के अनुसार नए हेडर पढ़ने, अपडेट करने या भेजने की अनुमति देता है।

समय समाप्ति

टाइमआउट को आसानी से उस URL में जोड़ा जा सकता है जिसे आप अजगर अनुरोध लाइब्रेरी का उपयोग करके अनुरोध कर रहे हैं। ऐसा होता है कि आप तृतीय-पक्ष URL का उपयोग कर रहे हैं और प्रतिक्रिया की प्रतीक्षा कर रहे हैं।

URL पर टाइमआउट देने के लिए हमेशा एक अच्छा अभ्यास है क्योंकि हम चाहते हैं कि URL उस समय-सीमा के भीतर प्रतिसाद दे या एक त्रुटि जो टाइमआउट के कारण आ रही है। ऐसा नहीं करने पर या तो उस अनुरोध पर अनिश्चित काल तक प्रतीक्षा की जा सकती है।

गलती संभालना

अनुरोध मॉड्यूल त्रुटि से निपटने के लिए समर्थन देता है और जिनमें से कुछ कनेक्शन त्रुटि, टाइमआउट त्रुटियां, TooManyRedirects, Response.raise_for_status त्रुटियां, आदि हैं।

कुकीज़

लाइब्रेरी आपको अनुरोधित URL को पढ़ने, लिखने और अपडेट करने की अनुमति देती है।

सत्र

डेटा को बनाए रखने के लिए, आपको अनुरोधों के बीच सत्रों की आवश्यकता होती है। इसलिए, यदि एक ही होस्ट को बार-बार कॉल किया जाता है, तो आप टीसीपी कनेक्शन का फिर से उपयोग कर सकते हैं जो बदले में प्रदर्शन में सुधार करेगा।

एसएसएल प्रमाणपत्र

एसएसएल प्रमाणपत्र एक सुरक्षा सुविधा है जो सुरक्षित यूआरएल के साथ आती है। जब आप अनुरोधों का उपयोग करते हैं, तो यह दिए गए https URL के लिए एसएसएल प्रमाणपत्रों की पुष्टि करता है। SSL सत्यापन अनुरोध लायब्रेरी में डिफ़ॉल्ट रूप से सक्षम है और प्रमाणपत्र मौजूद नहीं होने पर एक त्रुटि फेंक देगा।

प्रमाणीकरण

HTTP प्रमाणीकरण सर्वर-साइड पर है, जब क्लाइंट URL का अनुरोध करता है, तो उपयोगकर्ता नाम, पासवर्ड जैसी कुछ प्रमाणीकरण जानकारी मांगता है। यह अनुरोध और ग्राहक और सर्वर के बीच आदान-प्रदान की जा रही प्रतिक्रिया के लिए एक अतिरिक्त सुरक्षा है।

पायथन अनुरोध पुस्तकालय का उपयोग करने के लाभ

पायथन रिक्वेस्ट लाइब्रेरी का उपयोग करने के फायदे निम्नलिखित हैं -

  • दिए गए URL से डेटा का उपयोग करना और प्राप्त करना आसान है।

  • अनुरोध लाइब्रेरी का उपयोग वेबसाइट से डेटा खंगालने के लिए किया जा सकता है।

  • अनुरोधों का उपयोग करते हुए, आप दिए गए URL के डेटा को प्राप्त कर सकते हैं, पोस्ट कर सकते हैं, हटा सकते हैं।

  • कुकीज़ और सत्र की हैंडलिंग बहुत आसान है।

  • प्रमाणीकरण मॉड्यूल समर्थन की मदद से सुरक्षा का भी ध्यान रखा जाता है।

इस अध्याय में, हम अनुरोधों की स्थापना पर काम करेंगे। अनुरोध मॉड्यूल के साथ काम करना शुरू करने के लिए, हमें पहले पायथन स्थापित करना होगा। इसलिए हम निम्नलिखित पर काम करने जा रहे हैं

  • अजगर स्थापित करें
  • अनुरोध स्थापित करें

पायथन स्थापित करना

अजगर आधिकारिक साइट पर जाएं: https://www.python.org/downloads/जैसा कि नीचे दिखाया गया है और विंडोज, लिनक्स / यूनिक्स और मैक ओएस के लिए उपलब्ध नवीनतम संस्करण पर क्लिक करें। अपने साथ उपलब्ध 64 या 32 बिट ओएस के अनुसार अजगर डाउनलोड करें।

एक बार डाउनलोड करने के बाद, .exe फ़ाइल पर क्लिक करें और अपने सिस्टम पर अजगर को स्थापित करने के चरणों का पालन करें।

अजगर पैकेज मैनेजर, यानी, पाइप भी उपरोक्त स्थापना के साथ डिफ़ॉल्ट रूप से स्थापित हो जाएगा। अपने सिस्टम पर विश्व स्तर पर काम करने के लिए, सीधे अजगर के स्थान को पैथ वेरिएबल में जोड़ें। चेकबॉक्स को चेक करने के लिए याद रखने के लिए इंस्टॉलेशन के शुरू में ही दिखाया गया है जो ADD को PATH कहता है। यदि आप इसे जांचना भूल जाते हैं, तो कृपया PATH में जोड़ने के लिए नीचे दिए गए चरणों का पालन करें।

पथ में जोड़ने के लिए चरणों का पालन करें

अपने कंप्यूटर आइकन पर राइट-क्लिक करें और गुण> उन्नत सिस्टम सेटिंग्स पर क्लिक करें।

यह नीचे दिखाए गए अनुसार स्क्रीन प्रदर्शित करेगा -

ऊपर दिखाए गए अनुसार पर्यावरण चर पर क्लिक करें। यह नीचे दिखाए गए अनुसार स्क्रीन प्रदर्शित करेगा -

पथ का चयन करें और संपादन बटन पर क्लिक करें, अंत में अपने अजगर का स्थान पथ जोड़ें। अब, हम अजगर संस्करण की जांच करते हैं।

अजगर संस्करण की जाँच

E:\prequests>python --version
Python 3.7.3

अनुरोध स्थापित करें

अब जबकि हमने अजगर स्थापित कर दिया है, हम अनुरोध स्थापित करने जा रहे हैं।

एक बार अजगर स्थापित हो जाने के बाद, अजगर पैकेज मैनेजर यानी पाइप भी स्थापित हो जाएगा। निम्नलिखित पाइप संस्करण की जांच करने के लिए आदेश है।

E:\prequests>pip --version
pip 19.1.1 from c:\users\xxxxx\appdata\local\programs\python\python37\lib\site-p
ackages\pip (python 3.7)

हमारे पास पाइप स्थापित है और संस्करण 19.1.1 है। अब, अनुरोध मॉड्यूल को स्थापित करने के लिए पाइप का उपयोग करेगा।

आदेश नीचे दिया गया है −

pip install requests
E:\prequests>pip install requests
Requirement already satisfied: requests in c:\users\xxxx\appdata\local\programs
\python\python37\lib\site-packages (2.22.0)
Requirement already satisfied: certifi>=2017.4.17 in c:\users\kamat\appdata\loca
l\programs\python\python37\lib\site-packages (from requests) (2019.3.9)
Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in c:\use
rs\xxxxx\appdata\local\programs\python\python37\lib\site-packages (from requests
) (1.25.3)
Requirement already satisfied: idna<2.9,>=2.5 in c:\users\xxxxxxx\appdata\local\pr
ograms\python\python37\lib\site-packages (from requests) (2.8)
Requirement already satisfied: chardet<3.1.0,>=3.0.2 in c:\users\xxxxx\appdata\l
ocal\programs\python\python37\lib\site-packages (from requests) (3.0.4)

हमारे पास पहले से ही मॉड्यूल स्थापित है, इसलिए कमांड प्रॉम्प्ट में यह कहता है कि आवश्यकता पहले से ही संतुष्ट है; यदि स्थापित नहीं है, तो यह स्थापना के लिए आवश्यक संकुल डाउनलोड करेगा।

स्थापित मॉड्यूल के विवरण की जांच करने के लिए, आप निम्न कमांड का उपयोग कर सकते हैं

pip show requests
E:\prequests>pip show requests
Name: requests
Version: 2.22.0
Summary: Python HTTP for Humans.
Home-page: http://python-requests.org
Author: Kenneth Reitz
Author-email: [email protected]
License: Apache 2.0
Location: c:\users\xxxxx\appdata\local\programs\python\python37\lib\site-package
S
Requires: certifi, idna, urllib3, chardet
Required-by:

अनुरोध मॉड्यूल का संस्करण 2.22.0 है।

पायथन का अनुरोध एक HTTP पुस्तकालय है जो क्लाइंट और सर्वर के बीच डेटा का आदान-प्रदान करने में हमारी मदद करेगा। विचार करें कि आपके पास एक फ़ॉर्म के साथ UI है, जिसमें आपको उपयोगकर्ता विवरण दर्ज करने की आवश्यकता है, इसलिए एक बार जब आप इसे दर्ज करते हैं, तो आपको डेटा जमा करना होगा जो डेटा को बचाने के लिए क्लाइंट से सर्वर तक Http POST या PUT अनुरोध के अलावा कुछ नहीं है।

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

अनुरोध दिए गए URL से किया गया है और यह एक सुरक्षित या गैर-सुरक्षित URL हो सकता है।

URL का अनुरोध GET, POST, PUT, DELETE का उपयोग करके किया जा सकता है। सबसे अधिक इस्तेमाल किया जाने वाला GET तरीका है, जिसका इस्तेमाल मुख्य रूप से तब होता है जब आप सर्वर से डेटा लाना चाहते हैं।

आप उदाहरण के लिए क्वेरी स्ट्रिंग के रूप में URL को डेटा भी भेज सकते हैं

https://jsonplaceholder.typicode.com/users?id=9&username=Delphine

इसलिए यहाँ, हम URL पर id = 9 और उपयोगकर्ता नाम = Delphine पास कर रहे हैं। सभी मानों को प्रश्नवाचक चिह्न (?) के बाद कुंजी / मान युग्म में भेजा जाता है और एकाधिक पैराग्राफ URL से अलग कर दिए जाते हैं।

अनुरोध लाइब्रेरी का उपयोग करते हुए, URL को एक स्ट्रिंग शब्दकोश का उपयोग करते हुए कहा जाता है।

जिसमें URL को डेटा को स्ट्रिंग्स के शब्दकोश के रूप में भेजा जाता है। यदि आप id = 9 और उपयोगकर्ता नाम = Delphine पास करना चाहते हैं, तो आप निम्नानुसार कर सकते हैं

payload = {'id': '9', 'username': 'Delphine'}

अनुरोध पुस्तकालय को इस प्रकार कहा जाता है

res = requests.get('https://jsonplaceholder.typicode.com/users', params=payload')

POST का उपयोग करते हुए, हम निम्नानुसार कर सकते हैं

res = requests.post('https://jsonplaceholder.typicode.com/users', data = {'id':'9', 'username':'Delphine'})

PUT का उपयोग करना

res = requests.put('https://jsonplaceholder.typicode.com/users', data = {'id':'9', 'username':'Delphine'})

DELETE का उपयोग करना

res = requests.delete('https://jsonplaceholder.typicode.com/users')

Http रिक्वेस्ट की प्रतिक्रिया टेक्स्ट एनकोडेड फॉर्म, बाइनरी एनकोडेड, जसन फॉर्मेट या रॉ रिस्पॉन्स में हो सकती है। अनुरोध और प्रतिक्रिया का विवरण अगले अध्यायों में विस्तार से बताया गया है।

इस अध्याय में, हम समझेंगे कि अनुरोध मॉड्यूल के साथ कैसे काम किया जाए। हम निम्नलिखित में देखेंगे

  • HTTP अनुरोध करना।
  • HTTP रिक्वेस्ट के लिए पैरामीटर्स पास करना।

HTTP अनुरोध करना

Http अनुरोध करने के लिए, हमें पहले अनुरोध मॉड्यूल को आयात करना होगा जैसा कि नीचे दिखाया गया है

import requests

आइए अब देखते हैं, अनुरोध मॉड्यूल का उपयोग करके URL पर कॉल कैसे करें।

आइए हम URL us का उपयोग करें https://jsonplaceholder.typicode.com/users कोड में, अनुरोध मॉड्यूल का परीक्षण करने के लिए।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.status_code)

Url− https://jsonplaceholder.typicode.com/usersको request.get () विधि का उपयोग करके कहा जाता है। URL की प्रतिक्रिया ऑब्जेक्ट गेटडाटा चर में संग्रहीत है। जब हम चर को प्रिंट करते हैं, तो यह 200 प्रतिक्रिया कोड देता है, जिसका अर्थ है कि हमें सफलतापूर्वक प्रतिक्रिया मिली है।

उत्पादन

E:\prequests>python makeRequest.py
<Response [200]>

प्रतिक्रिया से सामग्री प्राप्त करने के लिए, हम इसका उपयोग कर सकते हैं getdata.content जैसा कि नीचे दिखाया गया है

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)

getdata.content, प्रतिक्रिया में उपलब्ध सभी डेटा को प्रिंट करेगा।

उत्पादन

E:\prequests>python makeRequest.py
b'[\n {\n  "id": 1,\n  "name": "Leanne Graham",\n  "username": "Bret",\n
"email": "[email protected]",\n  "address": {\n  "street": "Kulas Light
",\n  "suite": "Apt. 556",\n  "city": "Gwenborough",\n  "zipcode": "
92998-3874",\n  "geo": {\n "lat": "-37.3159",\n  "lng": "81.149
6"\n }\n },\n  "phone": "1-770-736-8031 x56442",\n  "website": "hild
egard.org",\n  "company": {\n "name": "Romaguera-Crona",\n  "catchPhr
ase": "Multi-layered client-server neural-net",\n  "bs": "harness real-time
e-markets"\n }\n }

HTTP रिक्वेस्ट के लिए पैरामीटर्स पास करना

बस URL का अनुरोध करना पर्याप्त नहीं है, हमें URL के मापदंडों को भी पास करना होगा।

परमेस ज्यादातर उदाहरण के लिए कुंजी / मूल्य जोड़ी के रूप में पारित किए जाते हैं

 https://jsonplaceholder.typicode.com/users?id=9&username=Delphine

तो, हमारे पास id = 9 और उपयोगकर्ता नाम = Delphine है। अब, Http मॉड्यूल अनुरोध करने के लिए इस तरह के डेटा को पास करने का तरीका देखेंगे।

उदाहरण

import requests
payload = {'id': 9, 'username': 'Delphine'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users', params=payload)
print(getdata.content)

विवरण कुंजी पेलोड / कुंजी जोड़ी में ऑब्जेक्ट पेलोड में संग्रहित किया जाता है और पैरामेस को पास कर दिया जाता है, अंदर () विधि।

उत्पादन

E:\prequests>python makeRequest.py
b'[\n {\n "id": 9,\n "name": "Glenna Reichert",\n "username": "Delphin
e",\n "email": "[email protected]",\n "address": {\n "street":
"Dayna Park",\n "suite": "Suite 449",\n "city": "Bartholomebury",\n
"zipcode": "76495-3109",\n "geo": {\n "lat": "24.6463",\n
"lng": "-168.8889"\n }\n },\n "phone": "(775)976-6794 x41206",\n "
website": "conrad.com",\n "company": {\n "name": "Yost and Sons",\n
"catchPhrase": "Switchable contextually-based project",\n "bs": "aggregate
real-time technologies"\n }\n }\n]'

अब हमें जवाब में आईडी = 9 और उपयोगकर्ता नाम = डेल्फिन का विवरण मिल रहा है।

यदि आप यह देखना चाहते हैं कि URL पैरामीटर को पार करने के बाद कैसा दिखता है, तो URL पर प्रतिक्रिया ऑब्जेक्ट का उपयोग करना।

उदाहरण

import requests
payload = {'id': 9, 'username': 'Delphine'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users', params=payload)
print(getdata.url)

उत्पादन

E:\prequests>python makeRequest.py
https://jsonplaceholder.typicode.com/users?id=9&username=Delphine

इस अध्याय में, हम अनुरोध मॉड्यूल से प्राप्त प्रतिक्रिया का अधिक विवरण प्राप्त करेंगे। हम निम्नलिखित विवरणों पर चर्चा करेंगे

  • रिस्पांस मिल रहा है
  • JSON प्रतिक्रिया
  • रॉ रिस्पांस
  • बाइनरी रिस्पांस

रिस्पांस मिल रहा है

हम URL को request.get () विधि का उपयोग करके अनुरोध करेंगे।

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users');

गेटडाटा के पास प्रतिक्रिया वस्तु है। इसमें प्रतिक्रिया का सारा विवरण है। हम (। पाठ ) और ( सामग्री ) का उपयोग करके 2 तरीकों से प्रतिक्रिया प्राप्त कर सकते हैं । Response.text का उपयोग करने से आपको पाठ प्रारूप में डेटा वापस मिल जाएगा जैसा कि नीचे दिखाया गया है

उदाहरण

E:\prequests>python makeRequest.py
[
 {
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
   }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered client-server neural-net",
   "bs": "harness real-time e-markets"
  }
},

आप देखेंगे कि प्रतिक्रिया वैसी ही है, जैसा कि जब आप नीचे दिखाए गए URL के लिए स्रोत देखते हैं तो यह ब्राउज़र में कैसे दिखाई देता होगा?

आप .html URL को भी आज़मा सकते हैं और response.text का उपयोग करके सामग्री देख सकते हैं, यह ब्राउज़र में .html URL के लिए दृश्य स्रोत सामग्री के समान होगा।

अब, हम उसी URL के लिए response.content आज़माएँ और आउटपुट देखें।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)

उत्पादन

E:\prequests>python makeRequest.py
b'[\n {\n "id": 1,\n "name": "Leanne Graham",\n "username": "Bret",\n
"email": "[email protected]",\n "address": {\n "street": "Kulas Light
",\n "suite": "Apt. 556",\n "city": "Gwenborough",\n "zipcode": "
92998-3874",\n "geo": {\n "lat": "-37.3159",\n "lng": "81.149
6"\n }\n },\n "phone": "1-770-736-8031 x56442",\n "website": "hild
egard.org",\n "company": {\n "name": "Romaguera-Crona",\n "catchPhr
ase": "Multi-layered client-server neural-net",\n "bs": "harness real-time
e-markets"\n }\n },\n {\n "id": 2,\n "name": "Ervin Howell",\n "us
ername": "Antonette",\n "email": "[email protected]",\n "address": {\n
"street": "Victor Plains",\n "suite": "Suite 879",\n "city": "Wisoky
burgh",\n "zipcode": "90566-7771",\n "geo": {\n "lat": "-43.950
9",\n "lng": "-34.4618"\n }\n },\n "phone": "010-692-6593 x091
25",\n "website": "anastasia.net",\n "company": {\n "name": "Deckow-C
rist",\n "catchPhrase": "Proactive didactic contingency",\n "bs": "syn
ergize scalable supply-chains"\n }\n },\n {\n "id": 3,\n "name": "Cle
mentine Bauch",\n "username": "Samantha",\n "email":
"[email protected]",
\n "address": {\n "street": "Douglas Extension",\n "suite": "Suite
847",\n "city": "McKenziehaven",\n "zipcode": "59590-4157",\n "ge
o": {\n "lat": "-68.6102",\n "lng": "-47.0653"\n }\n },\n

प्रतिक्रिया बाइट्स में दी गई है। आपको एक पत्र मिलेगाbप्रतिक्रिया की शुरुआत में। अनुरोध मॉड्यूल के साथ, आप उपयोग किए गए एन्कोडिंग प्राप्त कर सकते हैं और यदि आवश्यक हो तो एन्कोडिंग को भी बदल सकते हैं। उदाहरण के लिए, एन्कोडिंग प्राप्त करने के लिए आप response.encoding का उपयोग कर सकते हैं।

print(getdata.encoding)

उत्पादन

utf-8

आप एन्कोडिंग को निम्नानुसार बदल सकते हैं। आप अपनी पसंद के एन्कोडिंग का उपयोग कर सकते हैं।

getdata.encoding = 'ISO-8859-1'

JSON प्रतिक्रिया

आप प्रतिक्रिया स्वरूप json प्रारूप में Http अनुरोध के लिए प्रतिक्रिया प्राप्त कर सकते हैं

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.json())

उत्पादन

E:\prequests>python makeRequest.py
[{'id': 1, 'name': 'Leanne Graham', 'username': 'Bret', 'email': 'Sincere@april.
biz', 'address': {'street': 'Kulas Light', 'suite': 'Apt. 556', 'city': 'Gwenbor
ough', 'zipcode': '92998-3874', 'geo': {'lat': '-37.3159', 'lng': '81.1496'}},
'
phone': '1-770-736-8031 x56442', 'website': 'hildegard.org', 'company': {'name':
'Romaguera-Crona', 'catchPhrase': 'Multi-layered client-server neural-net', 'bs
': 'harness real-time e-markets'}}]

रॉ रिस्पांस

यदि आपको Http URL के लिए कच्ची प्रतिक्रिया की आवश्यकता है, तो आप response.raw का उपयोग कर सकते हैं, जोड़ भी सकते हैं stream=True नीचे दिखाए गए अनुसार विधि प्राप्त करें

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', stream=True)
print(getdata.raw)

उत्पादन

E:\prequests>python makeRequest.py
<urllib3.response.HTTPResponse object at 0x000000A8833D7B70>

कच्चे डेटा से अधिक सामग्री के लिए पढ़ने के लिए आप निम्नानुसार कर सकते हैं

print(getdata.raw.read(50))

उत्पादन

E:\prequests>python makeRequest.py
b'\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x03\x95\x98[o\xe38\x12\x85\xdf\xe7W\x10y\
xda\x01F\x82.\xd4m\x9f\xdc\x9dd\xba\xb7\x93\xf4\x06q\xef4\x06\x83A@K\x15\x89m'

बाइनरी रिस्पांस

द्विआधारी प्रतिक्रिया प्राप्त करने के लिए हम response.content का उपयोग कर सकते हैं।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)

उत्पादन

E:\prequests>python makeRequest.py
b'[\n {\n "id": 1,\n "name": "Leanne Graham",\n "username": "Bret",\n
"email": "[email protected]",\n "address": {\n "street": "Kulas Light
",\n "suite": "Apt. 556",\n "city": "Gwenborough",\n "zipcode": "
92998-3874",\n "geo": {\n "lat": "-37.3159",\n "lng": "81.149
6"\n }\n },\n "phone": "1-770-736-8031 x56442",\n "website": "hild
egard.org",\n "company": {\n "name": "Romaguera-Crona",\n "catchPhr
ase": "Multi-layered client-server neural-net",\n "bs": "harness real-time
e-markets"\n }\n },\n {\n "id": 2,\n "name": "Ervin Howell",\n "us
ername": "Antonette",\n "email": "[email protected]",\n "address": {\n
"street": "Victor Plains",\n "suite": "Suite 879",\n "city": "Wisoky
burgh",\n "zipcode": "90566-7771",\n "geo": {\n "lat": "-43.950
9",\n "lng": "-34.4618"\n }\n },\n "phone": "010-692-6593 x091
25",\n "website": "anastasia.net",\n "company": {\n "name": "Deckow-C
rist",\n "catchPhrase": "Proactive didactic contingency",\n "bs": "syn
ergize scalable supply-chains"\n }\n },\n {\n "id": 3,\n "name": "Cle
mentine Bauch",\n "username": "Samantha",\n "email": "[email protected]",
\n "address": {\n "street": "Douglas Extension",\n "suite": "Suite
847",\n "city": "McKenziehaven",\n "zipcode": "59590-4157",\n "ge
o": {\n "lat": "-68.6102",\n "lng": "-47.0653"\n }\n },\n

प्रतिक्रिया बाइट्स में दी गई है। आपको एक पत्र मिलेगाbप्रतिक्रिया की शुरुआत में। द्विआधारी प्रतिक्रिया का उपयोग ज्यादातर गैर-पाठ अनुरोधों के लिए किया जाता है।

अनुरोध - HTTP अनुरोध हेडर

पिछले अध्याय में, हमने देखा है कि अनुरोध कैसे करें और प्रतिक्रिया प्राप्त करें। यह अध्याय URL के हेडर सेक्शन पर थोड़ा और खोज करेगा। इसलिए, हम निम्नलिखित पर ध्यान देने जा रहे हैं

  • रिक्वेस्ट हेडर्स को समझना
  • कस्टम हेडर
  • रिस्पांस हेडर

रिक्वेस्ट हेडर्स को समझना

ब्राउज़र में किसी भी URL को हिट करें, उसका निरीक्षण करें और डेवलपर टूल नेटवर्क टैब में जांचें।

आपको प्रतिक्रिया हेडर, अनुरोध हेडर, पेलोड, आदि मिलेंगे।

उदाहरण के लिए, निम्नलिखित URL पर विचार करें

https://jsonplaceholder.typicode.com/users

आप शीर्षलेख विवरण निम्नानुसार प्राप्त कर सकते हैं

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', stream=True)
print(getdata.headers)

उत्पादन

E:\prequests>python makeRequest.py
{'Date': 'Sat, 30 Nov 2019 05:15:00 GMT', 'Content-Type': 'application/json; cha
rset=utf-8', 'Transfer-Encoding': 'chunked', 'Connection': 'keep-alive', 'Set-Co
okie': '__cfduid=d2b84ccf43c40e18b95122b0b49f5cf091575090900; expires=Mon, 30-De
c-19 05:15:00 GMT; path=/; domain=.typicode.com; HttpOnly', 'X-Powered-By': 'Exp
ress', 'Vary': 'Origin, Accept-Encoding', 'Access-Control-Allow-Credentials': 't
rue', 'Cache-Control': 'max-age=14400', 'Pragma': 'no-cache', 'Expires': '-1', '
X-Content-Type-Options': 'nosniff', 'Etag': 'W/"160d-1eMSsxeJRfnVLRBmYJSbCiJZ1qQ
"', 'Content-Encoding': 'gzip', 'Via': '1.1 vegur', 'CF-Cache-Status': 'HIT', 'A
ge': '2271', 'Expect-CT': 'max-age=604800, report-uri="https://report-uri.cloudf
lare.com/cdn-cgi/beacon/expect-ct"', 'Server': 'cloudflare', 'CF-RAY': '53da574f
f99fc331-SIN'}

किसी भी http हेडर को पढ़ने के लिए आप निम्नानुसार कर सकते हैं

getdata.headers["Content-Encoding"] // gzip

कस्टम हेडर

आप URL को हेडर भी भेज सकते हैं जिसे नीचे दिखाया गया है।

उदाहरण

import requests
headers = {'x-user': 'test123'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users', headers=headers)

पारित हेडर को स्ट्रिंग, बाइटस्ट्रिंग या यूनिकोड प्रारूप होना चाहिए। कस्टम हेडर के पारित होने के अनुसार अनुरोध का व्यवहार नहीं बदलेगा।

रिस्पांस हेडर

जब आप ब्राउज़र डेवलपर टूल, नेटवर्क टैब like में URL की जांच करते हैं तो प्रतिक्रिया शीर्षलेख नीचे की तरह दिखते हैं

अनुरोध मॉड्यूल के उपयोग से शीर्ष लेख का विवरण प्राप्त करने के लिए। प्रतिक्रिया. शीर्षकों को नीचे दिखाया गया है are

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.headers)

उत्पादन

E:\prequests>python makeRequest.py
{'Date': 'Sat, 30 Nov 2019 06:08:10 GMT', 'Content-Type': 'application/json; cha
rset=utf-8', 'Transfer-Encoding': 'chunked', 'Connection': 'keep-alive', 'Set-Co
okie': '__cfduid=de1158f1a5116f3754c2c353055694e0d1575094090; expires=Mon, 30-De
c-19 06:08:10 GMT; path=/; domain=.typicode.com; HttpOnly', 'X-Powered-By': 'Exp
ress', 'Vary': 'Origin, Accept-Encoding', 'Access-Control-Allow-Credentials': 't
rue', 'Cache-Control': 'max-age=14400', 'Pragma': 'no-cache', 'Expires': '-1', '
X-Content-Type-Options': 'nosniff', 'Etag': 'W/"160d-1eMSsxeJRfnVLRBmYJSbCiJZ1qQ
"', 'Content-Encoding': 'gzip', 'Via': '1.1 vegur', 'CF-Cache-Status': 'HIT', 'A
ge': '5461', 'Expect-CT': 'max-age=604800, report-uri="https://report-uri.cloudf
lare.com/cdn-cgi/beacon/expect-ct"', 'Server': 'cloudflare', 'CF-RAY': '53daa52f
3b7ec395-SIN'}

आप किसी भी विशिष्ट हेडर को निम्नानुसार प्राप्त कर सकते हैं

print(getdata.headers["Expect-CT"])

उत्पादन

max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/exp
ect-ct

You can also get the header details by using the get() method.

print(getdata.headers.get("Expect-CT"))

उत्पादन

max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/exp
ect-ct

अनुरोध - GET अनुरोध को संभालना

यह अध्याय GET अनुरोधों पर अधिक ध्यान केंद्रित करेगा, जो सबसे आम है और बहुत बार उपयोग किया जाता है। अनुरोध मॉड्यूल में GET का काम बहुत आसान है। यहां GET विधि का उपयोग करके URL के साथ काम करने के बारे में एक सरल उदाहरण है।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
getdata.content, will print all the data available in the response.

उत्पादन

E:\prequests>python makeRequest.py
b'[\n {\n "id": 1,\n "name": "Leanne Graham",\n "username": "Bret",\n
"email": "[email protected]",\n "address": {\n "street": "Kulas Light
",\n "suite": "Apt. 556",\n "city": "Gwenborough",\n "zipcode": "
92998-3874",\n "geo": {\n "lat": "-37.3159",\n "lng": "81.149
6"\n }\n },\n "phone": "1-770-736-8031 x56442",\n "website": "hild
egard.org",\n "company": {\n "name": "Romaguera-Crona",\n "catchPhr
ase": "Multi-layered client-server neural-net",\n "bs": "harness real-time
e-markets"\n }\n }

आप नीचे दिखाए गए अनुसार परम विशेषता का उपयोग करके प्राप्त विधि के लिए पैरामीटर भी पास कर सकते हैं

import requests
payload = {'id': 9, 'username': 'Delphine'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users',
params=payload)
print(getdata.content)

विवरण कुंजी पेलोड / कुंजी जोड़ी में ऑब्जेक्ट पेलोड में संग्रहित किया जाता है और पैरामेस को पास कर दिया जाता है, अंदर () विधि।

उत्पादन

E:\prequests>python makeRequest.py
b'[\n {\n "id": 9,\n "name": "Glenna Reichert",\n "username": "Delphin
e",\n "email": "[email protected]",\n "address": {\n "street":
"Dayna Park",\n "suite": "Suite 449",\n "city": "Bartholomebury",\n
"zipcode": "76495-3109",\n "geo": {\n "lat": "24.6463",\n
"lng": "-168.8889"\n }\n },\n "phone": "(775)976-6794 x41206",\n "
website": "conrad.com",\n "company": {\n "name": "Yost and Sons",\n
"catchPhrase": "Switchable contextually-based project",\n "bs": "aggregate
real-time technologies"\n }\n }\n]'

POST, PUT, PATCH और DELETE अनुरोधों को संभालना

इस अध्याय में, हम यह समझेंगे कि अनुरोध लाइब्रेरी का उपयोग करके POST विधि का उपयोग कैसे करें और URL के लिए पैरामीटर भी पास करें।

POST का उपयोग करना

PUT अनुरोध के लिए, अनुरोध लाइब्रेरी में request.post () विधि है, इसका उदाहरण नीचे दिखाया गया है:

आयात अनुरोध

myurl = 'https://postman-echo.com/post'
myparams = {'name': 'ABC', 'email':'[email protected]'}
res = requests.post(myurl, data=myparams)
print(res.text)

उत्पादन

E:\prequests>python makeRequest.py
{"args":{},"data":"","files":{},"form":{"name":"ABC","email":"[email protected]"},"headers":{"x-forwarded-proto":"https","host":"postman-echo.com","content-length":"30","accept":"*/*","accept-encoding":"gzip,deflate","content-type":"application/x-www-form-urlencoded","user-agent":"python-requests/2.22.0","x-forwarded-port":"443"},"json":{"name":"ABC","email":"[email protected]"},"url":"https://postman-echo.com/post"}

ऊपर दिखाए गए उदाहरण में, आप डेटा डेटा को मुख्य मानों के रूप में अनुरोधों के अंदर डेटा परम को पास कर सकते हैं। पोस्ट ()। हम यह भी देखेंगे कि अनुरोध मॉड्यूल में PUT, PATCH और DELETE के साथ कैसे काम करें।

PUT का उपयोग करना

PUT अनुरोध के लिए, अनुरोध लाइब्रेरी में request.put () विधि है, इसका उदाहरण नीचे दिखाया गया है।

import requests
myurl = 'https://postman-echo.com/put'
myparams = {'name': 'ABC', 'email':'[email protected]'}
res = requests.put(myurl, data=myparams)
print(res.text)

उत्पादन

E:\prequests>python makeRequest.py
{"args":{},"data":"","files":{},"form":{"name":"ABC","email":"[email protected]"},"h
eaders":{"x-forwarded-proto":"https","host":"postman-echo.com","content-length":
"30","accept":"*/*","accept-encoding":"gzip, deflate","content-type":"applicatio
n/x-www-form-urlencoded","user-agent":"python-requests/2.22.0","x-forwarded-port
":"443"},"json":{"name":"ABC","email":"[email protected]"},"url":"https://postman-ec ho.com/put"}

PATCH का उपयोग करना

PATCH अनुरोध के लिए, अनुरोध लाइब्रेरी में request.patch () विधि है, इसका उदाहरण नीचे दिखाया गया है।

import requests
myurl = https://postman-echo.com/patch'
res = requests.patch(myurl, data="testing patch")
print(res.text)

उत्पादन

E:\prequests>python makeRequest.py
{"args":{},"data":{},"files":{},"form":{},"headers":{"x-forwarded-proto":"https"
,"host":"postman-echo.com","content-length":"13","accept":"*/*","accept-encoding
":"gzip, deflate","user-agent":"python-requests/2.22.0","x-forwarded-port":"443"
},"json":null,"url":"https://postman-echo.com/patch"}

DELETE का उपयोग करना

DELETE अनुरोध के लिए, अनुरोध लाइब्रेरी में request.delete () विधि है, इसका उदाहरण नीचे दिखाया गया है।

import requests
myurl = 'https://postman-echo.com/delete'
res = requests.delete(myurl, data="testing delete")
print(res.text)

उत्पादन

E:\prequests>python makeRequest.py
{"args":{},"data":{},"files":{},"form":{},"headers":{"x-forwarded-proto":"https"
,"host":"postman-echo.com","content-length":"14","accept":"*/*","accept-encoding
":"gzip, deflate","user-agent":"python-requests/2.22.0","x-forwarded-port":"443"
},"json":null,"url":"https://postman-echo.com/delete"}

अनुरोध - फाइल अपलोड

इस अध्याय में, हम अनुरोध का उपयोग करके एक फ़ाइल अपलोड करेंगे और अपलोड की गई फ़ाइल की सामग्री को पढ़ेंगे। हम इसका उपयोग करके कर सकते हैंfiles नीचे दिए गए उदाहरण में दिखाया गया है।

हम उपयोग करेंगे http://httpbin.org/फ़ाइल अपलोड करने के लिए पोस्ट करें।

उदाहरण

import requests
myurl = 'https://httpbin.org/post'
files = {'file': open('test.txt', 'rb')}
getdata = requests.post(myurl, files=files)
print(getdata.text)

test.txt

File upload test using Requests

उदाहरण

var total = [0, 1, 2, 3].reduceRight(function(a, b){ return a + b; }); 
console.log("total is : " + total );

उत्पादन

E:\prequests>python makeRequest.py
{
  "args": {},
  "data": "",
  "files": {
   "file": "File upload test using Requests"
  },
  "form": {},
  "headers": {
   "Accept": "*/*",
   "Accept-Encoding": "gzip, deflate",
   "Content-Length": "175",
   "Content-Type": "multipart/form-data; 
boundary=28aee3a9d15a3571fb80d4d2a94bf
d33",
   "Host": "httpbin.org",
   "User-Agent": "python-requests/2.22.0"
  },
  "json": null,
  "origin": "117.223.63.135, 117.223.63.135",
  "url": "https://httpbin.org/post"
}

नीचे दिखाए अनुसार फ़ाइल की सामग्री भेजना भी संभव है

उदाहरण

import requests
myurl = 'https://httpbin.org/post'
files = {'file': ('test1.txt', 'Welcome to TutorialsPoint')}
getdata = requests.post(myurl, files=files)
print(getdata.text)

उत्पादन

E:\prequests>python makeRequest.py
{
  "args": {},
  "data": "",
  "files": {
   "file": "Welcome to TutorialsPoint"
},
"form": {},
"headers": {
   "Accept": "*/*",
   "Accept-Encoding": "gzip, deflate",
   "Content-Length": "170",
   "Content-Type": "multipart/form-data; boundary=f2837238286fe40e32080aa7e172b
e4f",
  "Host": "httpbin.org",
  "User-Agent": "python-requests/2.22.0"
},
  "json": null,
  "origin": "117.223.63.135, 117.223.63.135",
  "url": "https://httpbin.org/post"
}

अनुरोध - कुकीज़ के साथ काम करना

इस अध्याय में कुकीज़ से निपटने के तरीके पर चर्चा की जाएगी। आप अनुरोध लायब्रेरी का उपयोग करके URL को कॉल करते समय कुकीज़ प्राप्त कर सकते हैं और साथ ही अपने कुकीज़ भेज सकते हैं।

Url, https://jsonplaceholder.typicode.com/users ब्राउज़र में हिट होने पर हम कुकीज़ का विवरण नीचे दिखाए अनुसार प्राप्त कर सकते हैं

आप कुकीज़ को नीचे दिखाए अनुसार पढ़ सकते हैं

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.cookies["__cfduid"])

उत्पादन

E:\prequests>python makeRequest.py
d1733467caa1e3431fb7f768fa79ed3741575094848

अनुरोध करने पर आप कुकीज़ भी भेज सकते हैं।

उदाहरण

import requests
cookies = dict(test='test123')
getdata = requests.get('https://httpbin.org/cookies',cookies=cookies)
print(getdata.text)

उत्पादन

E:\prequests>python makeRequest.py
{
   "cookies": {
   "test": "test123"
}
}

अनुरोध - त्रुटियों के साथ काम करना

यह अध्याय चर्चा करेगा कि Http अनुरोध पुस्तकालय के साथ काम करते समय आने वाली त्रुटियों से कैसे निपटें। सभी संभावित मामलों के लिए त्रुटियों का प्रबंधन करना हमेशा एक अच्छा अभ्यास होता है।

त्रुटि अपवाद

अनुरोध मॉड्यूल निम्न प्रकार की त्रुटि अपवाद देता है

ConnectionError- कनेक्शन की त्रुटि होने पर इसे उठाया जाएगा। उदाहरण के लिए, नेटवर्क विफल, DNS त्रुटि इसलिए अनुरोध लाइब्रेरी कनेक्शन कनेक्शन को बढ़ा देगी।

Response.raise_for_status()- स्थिति कोड यानी 401, 404 के आधार पर यह आग्रह किए गए यूआरएल के लिए HTTPError बढ़ाएगा।

HTTPError- यह त्रुटि किए गए अनुरोध के लिए अमान्य प्रतिक्रिया के लिए उठाई जाएगी।

Timeout- अनुरोध किए गए URL के लिए समय-सीमा के लिए त्रुटियाँ।

TooManyRedirects- अगर सीमा को अधिकतम पुनर्निर्देशन के लिए पार कर लिया जाता है तो यह बहुत अधिक त्रुटि को बढ़ा देगा।

उदाहरण

यहां टाइमआउट के लिए दिखाई गई त्रुटियों का एक उदाहरण है

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)

उत्पादन

raise ConnectTimeout(e, request=request)
requests.exceptions.ConnectTimeout: HTTPSConnectionPool(host='jsonplaceholder.ty
picode.com', port=443): Max retries exceeded with url: /users (Caused by Connect
TimeoutError(<urllib3.connection.VerifiedHTTPSConnection object at
0x000000B02AD
E76A0>, 'Connection to jsonplaceholder.typicode.com timed out. (connect timeout= 0.001)'))

अनुरोध - टाइमआउट को संभालना

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

हम टाइमआउट परम का उपयोग करके URL को टाइमआउट दे सकते हैं और मूल्य सेकंड में पारित किया जाता है जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)

उत्पादन

raise ConnectTimeout(e, request=request)
requests.exceptions.ConnectTimeout: HTTPSConnectionPool(host='jsonplaceholder.ty
picode.com', port=443): Max retries exceeded with url: /users (Caused by Connect
TimeoutError(<urllib3.connection.VerifiedHTTPSConnection object at 0x000000B02AD
E76A0>, 'Connection to jsonplaceholder.typicode.com timed out. (connect timeout=
0.001)'))

दिया गया टाइमआउट इस प्रकार है

getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)

निष्पादन कनेक्शन टाइमआउट त्रुटि को आउटपुट में दिखाया गया है। दिया गया टाइमआउट 0.001 है, जो प्रतिक्रिया को वापस पाने के अनुरोध के लिए संभव नहीं है और एक त्रुटि फेंकता है। अब, हम समय-सीमा बढ़ाएँगे और जाँच करेंगे।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=1.000)
print(getdata.text)

उत्पादन

E:\prequests>python makeRequest.py
[
 {
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
   }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered client-server neural-net",
   "bs": "harness real-time e-markets"
 }

1 सेकंड के टाइमआउट के साथ, हम अनुरोध किए गए URL के लिए प्रतिक्रिया प्राप्त कर सकते हैं।

अनुरोध - पुनर्निर्देशन को संभालना

यह अध्याय इस बात पर ध्यान देगा कि अनुरोध लाइब्रेरी url पुनर्निर्देशन मामले को कैसे संभालती है।

उदाहरण

import requests
getdata = requests.get('http://google.com/')
print(getdata.status_code)
print(getdata.history)

Url− http://google.com स्थिति कोड 301 (स्थायी रूप से स्थानांतरित) का उपयोग करके पुनर्निर्देशित किया जाएगा https://www.google.com/। इतिहास में पुनर्निर्देशन को सहेजा जाएगा।

उत्पादन

जब उपरोक्त कोड निष्पादित होता है, तो हमें निम्नलिखित परिणाम मिलते हैं

E:\prequests>python makeRequest.py
200
[<Response [301]>]

आप किसी URL का उपयोग करके पुनर्निर्देशन रोक सकते हैं allow_redirects=False। यह GET, POST, OPTIONS, PUT, DELETE, PATCH पद्धतियों पर किया जा सकता है।

उदाहरण

यहाँ उसी पर एक उदाहरण दिया गया है।

import requests
getdata = requests.get('http://google.com/', allow_redirects=False)
print(getdata.status_code)
print(getdata.history)
print(getdata.text)

अब यदि आप आउटपुट चेक करते हैं, तो पुनर्निर्देशन की अनुमति नहीं होगी और 301 का स्टेटस कोड मिलेगा।

उत्पादन

E:\prequests>python makeRequest.py
301
[]
<HTML><HEAD><meta http-equiv="content-type" content="text/html;charset=utf-8">
<TITLE>301 Moved</TITLE></HEAD><BODY>
<H1>301 Moved</H1>
The document has moved
<A HREF="http://www.google.com/">here</A>.
</BODY></HTML>

अनुरोध - इतिहास को संभालना

आप किसी दिए गए URL का उपयोग करके इतिहास प्राप्त कर सकते हैं response.history। यदि दिए गए URL में कोई रीडायरेक्ट है, तो वही इतिहास में संग्रहीत किया जाएगा।

इतिहास के लिए

import requests
getdata = requests.get('http://google.com/')
print(getdata.status_code)
print(getdata.history)

उत्पादन

E:\prequests>python makeRequest.py
200
[<Response [301]>]

response.historyसंपत्ति में प्रतिक्रिया वस्तुओं का विवरण होगा जो अनुरोध के आधार पर किया गया था। मौजूद मानों को सबसे पुराने से नवीनतम लोगों की तरह छाँटा जाएगा। response.history संपत्ति अनुरोध किए गए URL पर किए गए सभी पुनर्निर्देशन को ट्रैक करती है।

अनुरोध - सत्रों को संभालना

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

सत्र का उपयोग करके कुकीज़ जोड़ना

import requests
req = requests.Session()
cookies = dict(test='test123')
getdata = req.get('https://httpbin.org/cookies',cookies=cookies)
print(getdata.text)

उत्पादन

E:\prequests>python makeRequest.py
{
   "cookies": {
   "test": "test123"
}
}

सत्र का उपयोग करके, आप अनुरोधों पर कुकीज़ डेटा संरक्षित कर सकते हैं। नीचे दिए गए अनुसार सत्र का उपयोग करके हेडर डेटा को पास करना भी संभव है

उदाहरण

import requests
req = requests.Session()
req.headers.update({'x-user1': 'ABC'})
headers = {'x-user2': 'XYZ'}
getdata = req.get('https://httpbin.org/headers', headers=headers)    
print(getdata.headers)

अनुरोध - एसएसएल प्रमाणन

एसएसएल प्रमाणपत्र एक सुरक्षा सुविधा है जो सुरक्षित यूआरएल के साथ आती है। जब आप अनुरोध लाइब्रेरी का उपयोग करते हैं, तो यह दिए गए https URL के लिए एसएसएल प्रमाणपत्रों की पुष्टि करता है। SSL सत्यापन अनुरोध मॉड्यूल में डिफ़ॉल्ट रूप से सक्षम है और प्रमाणपत्र मौजूद नहीं होने पर एक त्रुटि फेंक देगा।

सुरक्षित URL के साथ कार्य करना

निम्नलिखित सुरक्षित URL− के साथ काम करने का उदाहरण है

import requests
getdata = requests.get(https://jsonplaceholder.typicode.com/users)
print(getdata.text)

उत्पादन

E:\prequests>python makeRequest.py
[
   {
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
   }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered client-server neural-net",
   "bs": "harness real-time e-markets"
   }
  }
]

हमें उपरोक्त https URL से आसानी से प्रतिक्रिया मिल रही है, और यह इसलिए है क्योंकि अनुरोध मॉड्यूल SSL प्रमाणपत्र को सत्यापित कर सकता है।

आप केवल नीचे दिए गए उदाहरण में दिखाए गए सत्यापन = गलत जोड़कर SSL सत्यापन को अक्षम कर सकते हैं।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', verify=False)
print(getdata.text)

आपको आउटपुट मिलेगा, लेकिन यह एक चेतावनी संदेश भी देगा कि, एसएसएल प्रमाणपत्र सत्यापित नहीं है और प्रमाणपत्र सत्यापन जोड़ने की सलाह दी जाती है।

उत्पादन

E:\prequests>python makeRequest.py
connectionpool.py:851: InsecureRequestWarning: Unverified HTTPS request is being
made. Adding certificate verification is strongly advised. See: https://urllib3
   .readthedocs.io/en/latest/advanced-usage.htm  l#ssl-warnings
 InsecureRequestWarning)
[
 {
  "id": 1,
   "name": "Leanne Graham",
   "username": "Bret", 
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
   }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered   client-server neural-net",
   "bs": "harness real-time e-markets"
  }
 }
]

आप एसएसएल प्रमाणपत्र को अपने अंत में होस्ट करके, और उपयोग करके पथ को सत्यापित भी कर सकते हैं verify नीचे दिखाया गया है।

उदाहरण

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', verify='C:\Users\AppData\Local\certificate.txt')
print(getdata.text)

उत्पादन

E:\prequests>python makeRequest.py
[
  {
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
   }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered   client-server neural-net",
   "bs": "harness real-time e-markets"
   }
  }
]

अनुरोध - प्रमाणीकरण

यह अध्याय अनुरोध मॉड्यूल में उपलब्ध प्रमाणीकरण के प्रकारों पर चर्चा करेगा।

हम निम्नलिखित पर चर्चा करने जा रहे हैं

  • HTTP अनुरोधों में प्रमाणीकरण का कार्य

  • मूल प्रमाणीकरण

  • डाइजेस्ट ऑथेंटिकेशन

  • OAuth2 प्रमाणीकरण

HTTP अनुरोधों में प्रमाणीकरण का कार्य

HTTP प्रमाणीकरण सर्वर-साइड पर है, जब क्लाइंट URL का अनुरोध करता है, तो उपयोगकर्ता नाम, पासवर्ड जैसी कुछ प्रमाणीकरण जानकारी मांगता है। यह क्लाइंट और सर्वर के बीच अनुरोध और प्रतिक्रिया के लिए अतिरिक्त सुरक्षा है।

क्लाइंट-साइड से ये अतिरिक्त प्रमाणीकरण जानकारी अर्थात उपयोगकर्ता नाम और पासवर्ड हेडर में भेजे जा सकते हैं, जिसे बाद में सर्वर साइड पर मान्य किया जाएगा। प्रमाणीकरण मान्य होने पर ही सर्वर-साइड से प्रतिक्रिया दी जाएगी।

अनुरोध लाइब्रेरी में अनुरोधों में सबसे अधिक उपयोग किया जाने वाला प्रमाणीकरण है। ऑथ , जो बेसिक ऑथेंटिकेशन ( HTTPBasicAuth ) और डाइजेस्ट ऑथेंटिकेशन ( HTTPDigestAuth ) हैं।

मूल प्रमाणीकरण

यह सर्वर को प्रमाणीकरण प्रदान करने का सबसे सरल रूप है। बुनियादी प्रमाणीकरण के साथ काम करने के लिए, हम अनुरोध लाइब्रेरी के साथ उपलब्ध HTTPBasicAuth क्लास का उपयोग करने जा रहे हैं।

उदाहरण

इसका उपयोग कैसे करना है, इसका एक कार्य उदाहरण यहां दिया गया है।

import requests
from requests.auth import HTTPBasicAuth
response_data = requests.get('httpbin.org/basic-auth/admin/admin123', auth=HTTPDigestAuth('admin', 'admin123'))
print(response_data.text)

हम url को कॉल कर रहे हैं, https://httpbin.org/basic-auth/admin/admin123के रूप में उपयोगकर्ता के साथ व्यवस्थापक और पासवर्ड के रूप admin123

तो, यह URL प्रमाणीकरण के बिना काम नहीं करेगा, अर्थात उपयोगकर्ता और पासवर्ड। एक बार जब आप ऑरिजनल परम का उपयोग करके ऑथेंटिकेशन देते हैं, तो केवल सर्वर ही प्रतिक्रिया देगा।

उत्पादन

E:\prequests>python makeRequest.py
{
   "authenticated": true,
   "user": "admin"
}

डाइजेस्ट ऑथेंटिकेशन

यह अनुरोधों के साथ उपलब्ध प्रमाणीकरण का दूसरा रूप है। हम अनुरोधों से HTTPDigestAuth क्लास का उपयोग करने जा रहे हैं।

उदाहरण

import requests
from requests.auth import HTTPDigestAuth
response_data = requests.get('https://httpbin.org/digest-auth/auth/admin/admin123>, auth=HTTPDigestAuth('admin', 'admin123'))
print(response_data.text)

उत्पादन

E:\prequests>python makeRequest.py
{
   "authenticated": true,
   "user": "admin"
}

OAuth2 प्रमाणीकरण

OAuth2 प्रमाणीकरण का उपयोग करने के लिए, हमें "request_oauth2" लाइब्रेरी की आवश्यकता है। "Request_oauth2" को स्थापित करने के लिए निम्नलिखित कार्य करें

pip install requests_oauth2

स्थापित करते समय आपके टर्मिनल में प्रदर्शन नीचे दिखाए गए अनुसार कुछ होगा

E:\prequests>pip install requests_oauth2
Collecting requests_oauth2
Downloading https://files.pythonhosted.org/packages/52/dc/01c3c75e6e7341a2c7a9
71d111d7105df230ddb74b5d4e10a3dabb61750c/requests-oauth2-0.3.0.tar.gz
Requirement already satisfied: requests in c:\users\xyz\appdata\local\programs
\python\python37\lib\site-packages (from requests_oauth2) (2.22.0)
Requirement already satisfied: six in c:\users\xyz\appdata\local\programs\pyth
on\python37\lib\site-packages (from requests_oauth2) (1.12.0)
Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in c:\use
rs\xyz\appdata\local\programs\python\python37\lib\site-packages (from requests
->requests_oauth2) (1.25.3)
Requirement already satisfied: certifi>=2017.4.17 in c:\users\xyz\appdata\loca
l\programs\python\python37\lib\site-packages (from requests->requests_oauth2) (2
019.3.9)
Requirement already satisfied: chardet<3.1.0,>=3.0.2 in c:\users\xyz\appdata\l
ocal\programs\python\python37\lib\site-packages (from requests->requests_oauth2)
(3.0.4)
Requirement already satisfied: idna<2.9,>=2.5 in c:\users\xyz\appdata\local\pr
ograms\python\python37\lib\site-packages (from requests->requests_oauth2) (2.8)
Building wheels for collected packages: requests-oauth2
Building wheel for requests-oauth2 (setup.py) ... done
Stored in directory: C:\Users\xyz\AppData\Local\pip\Cache\wheels\90\ef\b4\43
3743cbbc488463491da7df510d41c4e5aa28213caeedd586
Successfully built requests-oauth2

हम "अनुरोध-oauth2" स्थापित कर रहे हैं। Google, Twitter के API का उपयोग करने के लिए हमें इसकी सहमति की आवश्यकता होती है और OAuth2 प्रमाणीकरण का उपयोग करके किया जाता है।

OAuth2 प्रमाणीकरण के लिए हमें क्लाइंट आईडी और एक गुप्त कुंजी की आवश्यकता होगी। इसे कैसे प्राप्त किया जाए, इसका विवरण दिया गया हैhttps://developers.google.com/identity/protocols/OAuth2।

बाद में, Google API कंसोल पर लॉग इन करें जो कि उपलब्ध है https://console.developers.google.com/और क्लाइंट आईडी और गुप्त कुंजी प्राप्त करें।

उदाहरण

यहाँ "अनुरोध-oauth2" का उपयोग करने का एक उदाहरण दिया गया है।

import requests
from requests_oauth2.services import GoogleClient
google_auth = GoogleClient(
   client_id="xxxxxxxxxxxxxxxxxxxxxxxxxx.apps.googleusercontent.com",
redirect_uri="http://localhost/auth/success.html",
)
a = google_auth.authorize_url(
   scope=["profile", "email"],
   response_type="code",
)
res = requests.get(a)
print(res.url)

हम दिए गए URL पर पुनर्निर्देशित नहीं कर पाएंगे, क्योंकि इसके लिए Gmail खाते में लॉगिन करना होगा, लेकिन यहां, आप उदाहरण से देखेंगे, कि google_auth काम करता है और अधिकृत URL दिया गया है।

उत्पादन

E:\prequests>python oauthRequest.py
https://accounts.google.com/o/oauth2/auth?redirect_uri=
http%3A%2F%2Flocalhost%2Fauth%2Fsuccess.html&
client_id=xxxxxxxxxxxxxxxxxxxxx.apps.googleusercontent.com&
scope=profile+email&response_type=code

अनुरोध - ईवेंट हुक

हम ईवेंट हुक का उपयोग करके अनुरोध किए गए URL में ईवेंट जोड़ सकते हैं। नीचे दिए गए उदाहरण में, हम एक कॉलबैक फ़ंक्शन जोड़ने जा रहे हैं जो प्रतिक्रिया मिलने पर कॉल करेगा।

उदाहरण

कॉलबैक जोड़ने के लिए, हमें हुक परम का उपयोग करने की आवश्यकता है जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है

mport requests
def printData(r, *args, **kwargs):
   print(r.url)
   print(r.text)
getdata = requests.get('https://jsonplaceholder.typicode.com/users', 
hooks={'response': printData})

उत्पादन

E:\prequests>python makeRequest.py
https://jsonplaceholder.typicode.com/users
[
{
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
    "lat": "-37.3159",
    "lng": "81.1496"
   }
  }, 
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered client-server neural-net",
   "bs": "harness real-time e-markets"
   }
  }
]

आप नीचे दिखाए गए अनुसार कई कॉलबैक फ़ंक्शन भी कॉल कर सकते हैं

उदाहरण

import requests
def printRequestedUrl(r, *args, **kwargs):
   print(r.url)
def printData(r, *args, **kwargs):
   print(r.text)
getdata = requests.get('https://jsonplaceholder.typicode.com/users', hooks={'response': [printRequestedUrl, printData]})

उत्पादन

E:\prequests>python makeRequest.py
https://jsonplaceholder.typicode.com/users
[
  {
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
 }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered client-server neural-net",
    "bs": "harness real-time e-markets"
   }
  }
]

आप नीचे दिए गए सत्र के अनुसार बनाए गए हुक को भी जोड़ सकते हैं

उदाहरण

import requests
def printData(r, *args, **kwargs):
print(r.text)
s = requests.Session()
s.hooks['response'].append(printData)
s.get('https://jsonplaceholder.typicode.com/users')

उत्पादन

E:\prequests>python makeRequest.py
[
 {
   "id": 1,
   "name": "Leanne Graham",
   "username": "Bret",
   "email": "[email protected]",
   "address": {
   "street": "Kulas Light",
   "suite": "Apt. 556",
   "city": "Gwenborough",
   "zipcode": "92998-3874",
   "geo": {
   "lat": "-37.3159",
   "lng": "81.1496"
   }
  },
   "phone": "1-770-736-8031 x56442",
   "website": "hildegard.org",
   "company": {
   "name": "Romaguera-Crona",
   "catchPhrase": "Multi-layered client-server neural-net",
   "bs": "harness real-time e-markets"
   }
  }
]

अनुरोध - प्रॉक्सी

अब तक, हमने क्लाइंट्स को सर्वर से सीधे कनेक्ट और बात करते देखा है। प्रॉक्सी का उपयोग करते हुए, बातचीत निम्नानुसार होती है

  • क्लाइंट प्रॉक्सी के लिए एक अनुरोध भेजता है।

  • प्रॉक्सी सर्वर को अनुरोध भेजती है।

  • सर्वर प्रॉक्सी को प्रतिक्रिया भेजता है।

  • प्रॉक्सी क्लाइंट को एक प्रतिक्रिया भेजेगा।

क्लाइंट और सर्वर के बीच डेटा विनिमय का प्रबंधन करने के लिए Http-प्रॉक्सी का उपयोग अतिरिक्त सुरक्षा को सौंपा गया है। अनुरोध पुस्तकालयों में प्रॉक्सी को संभालने का भी प्रावधान है, नीचे दिए गए अनुसार प्रॉक्सिम परम का उपयोग करके

उदाहरण

import requests
proxies = {
'http': 'http://localhost:8080'
}
res = requests.get('http://httpbin.org/', proxies=proxies)
print(res.status_code)

अनुरोध मार्ग के लिए होगा ('http://localhost:8080 यूआरएल।

उत्पादन

200

अनुरोध - अनुरोध का उपयोग करके वेब स्क्रैपिंग

हमने पहले ही देखा है कि हम किसी भी URL से अजगर अनुरोध लाइब्रेरी का उपयोग करके डेटा कैसे प्राप्त कर सकते हैं। हम साइट से डेटा को स्क्रैप करने का प्रयास करेंगेTutorialspoint जो उपलब्ध है https://www.tutorialspoint.com/tutorialslibrary.htm निम्नलिखित का उपयोग करना

  • अनुरोध पुस्तकालय

  • अजगर से सुंदर सूप पुस्तकालय

हमने पहले ही रिक्वेस्ट लाइब्रेरी स्थापित कर ली है, आइए अब ब्यूटीफुल सूप पैकेज स्थापित करें यहाँ के लिए आधिकारिक वेबसाइट हैbeautiful soup पर उपलब्ध https://www.crummy.com/software/BeautifulSoup/bs4/doc/ मामले में आप सुंदर सूप के कुछ और कार्यात्मकता का पता लगाना चाहते हैं।

Sundsoup स्थापित करना

हम नीचे सुंदर सूप स्थापित करने का तरीका देखेंगे

E:\prequests>pip install beautifulsoup4
Collecting beautifulsoup4
Downloading https://files.pythonhosted.org/packages/3b/c8/a55eb6ea11cd7e5ac4ba
cdf92bac4693b90d3ba79268be16527555e186f0/beautifulsoup4-4.8.1-py3-none-any.whl (
101kB)
|████████████████████████████████| 102kB 22kB/s
Collecting soupsieve>=1.2 (from beautifulsoup4)
Downloading https://files.pythonhosted.org/packages/81/94/03c0f04471fc245d08d0
a99f7946ac228ca98da4fa75796c507f61e688c2/soupsieve-1.9.5-py2.py3-none-any.whl
Installing collected packages: soupsieve, beautifulsoup4
Successfully installed beautifulsoup4-4.8.1 soupsieve-1.9.5

अब हमारे पास लाइब्रेरी और सुंदर सूप के लिए अजगर के अनुरोध हैं।

अब हम कोड लिखते हैं, जो दिए गए URL से डेटा को स्क्रैप करेगा।

वेब स्क्रेपिंग

import requests
from bs4 import BeautifulSoup
res = requests.get('https://www.tutorialspoint.com/tutorialslibrary.htm')
print("The status code is ", res.status_code)
print("\n")
soup_data = BeautifulSoup(res.text, 'html.parser')
print(soup_data.title)
print("\n")
print(soup_data.find_all('h4'))

अनुरोध लाइब्रेरी का उपयोग करके, हम दिए गए URL से सामग्री प्राप्त कर सकते हैं और सुंदर सूप लाइब्रेरी इसे पार्स करने में मदद करती है और विवरण को जिस तरह से हम चाहते हैं उसे प्राप्त कर सकते हैं।

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

उत्पादन

E:\prequests>python makeRequest.py
The status code is 200
<title>Free Online Tutorials and Courses</title>
[<h4>Academic</h4>, <h4>Computer Science</h4>, <h4>Digital Marketing</h4>, <h4>M
onuments</h4>,<h4>Machine Learning</h4>, <h4>Mathematics</h4>, <h4>Mobile Devel
opment</h4>,<h4>SAP</h4>, <h4>Software Quality</h4>, <h4>Big Data & Analyti
cs</h4>, <h4>Databases</h4>, <h4>Engineering Tutorials</h4>, <h4>Mainframe Devel
opment</h4>, <h4>Microsoft Technologies</h4>, <h4>Java Technologies</h4>,<h4>XM
L Technologies</h4>, <h4>Python Technologies</h4>, <h4>Sports</h4>, <h4>Computer
Programming</h4>,<h4>DevOps</h4>, <h4>Latest Technologies</h4>, <h4>Telecom</h4>, <h4>Exams Syllabus</h4>, <h4>UPSC IAS Exams</h4>, <h4>Web Development</h4>,
<h4>Scripts</h4>, <h4>Management</h4>,<h4>Soft Skills</h4>, <h4>Selected Readin
g</h4>, <h4>Misc</h4>]