अनुरोध - प्रमाणीकरण
यह अध्याय अनुरोध मॉड्यूल में उपलब्ध प्रमाणीकरण के प्रकारों पर चर्चा करेगा।
हम निम्नलिखित पर चर्चा करने जा रहे हैं -
- 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