Demandes - Guide rapide
Requests est une bibliothèque HTTP qui fournit des fonctionnalités simples pour traiter les requêtes / réponses http dans votre application Web. La bibliothèque est développée en python.
Le site officiel de Python Requests qui est disponible sur https://2.python-requests.org/en/master/ définit les demandes comme suit -
Requests est une bibliothèque HTTP élégante et simple pour Python, conçue pour les êtres humains.
Caractéristiques des demandes
Les caractéristiques des demandes sont décrites ci-dessous -
Demande
La bibliothèque de requêtes python dispose de méthodes faciles à utiliser pour gérer les requêtes Http. Passer des paramètres et gérer le type de requête comme GET, POST, PUT, DELETE, etc. est très simple.
Réponse
Vous pouvez obtenir la réponse dans le format dont vous avez besoin et les réponses prises en charge sont le format texte, la réponse binaire, la réponse json et la réponse brute.
En-têtes
La bibliothèque vous permet de lire, mettre à jour ou envoyer de nouveaux en-têtes selon vos besoins.
Timeouts
Les délais d'expiration peuvent être facilement ajoutés à l'URL que vous demandez à l'aide de la bibliothèque de requêtes python. Il se trouve que vous utilisez une URL tierce et que vous attendez une réponse.
Il est toujours recommandé de donner un délai d'expiration sur l'URL car nous souhaitons peut-être que l'URL réponde dans ce délai avec une réponse ou une erreur qui survient en raison du délai d'expiration. Ne pas le faire peut amener l'un ou l'autre à attendre indéfiniment cette demande.
La gestion des erreurs
Le module de requêtes prend en charge la gestion des erreurs et dont certaines sont des erreurs de connexion, des erreurs de délai d'expiration, des erreurs TooManyRedirects, Response.raise_for_status, etc.
Biscuits
La bibliothèque vous permet de lire, d'écrire et de mettre à jour l'URL demandée.
Séances
Pour maintenir les données, vous avez besoin entre les demandes, vous avez besoin de sessions. Ainsi, si le même hôte est appelé encore et encore, vous pouvez réutiliser la connexion TCP, ce qui améliorera les performances.
Certificats SSL
Le certificat SSL est une fonctionnalité de sécurité fournie avec des URL sécurisées. Lorsque vous utilisez Requests, il vérifie également les certificats SSL pour l'URL https donnée. La vérification SSL est activée par défaut dans la bibliothèque de requêtes et générera une erreur si le certificat n'est pas présent.
Authentification
L'authentification HTTP est du côté serveur demandant des informations d'authentification comme le nom d'utilisateur, le mot de passe lorsque le client demande une URL. Il s'agit d'une sécurité supplémentaire pour la requête et la réponse échangées entre le client et le serveur.
Avantages de l'utilisation de la bibliothèque de requêtes Python
Voici les avantages de l'utilisation de la bibliothèque de requêtes Python -
Facile à utiliser et à récupérer les données à partir de l'URL donnée.
La bibliothèque de demandes peut être utilisée pour récupérer les données du site Web.
À l'aide de requêtes, vous pouvez obtenir, publier, supprimer, mettre à jour les données de l'URL donnée.
La gestion des cookies et de la session est très simple.
La sécurité est également prise en charge à l'aide du support du module d'authentification.
Dans ce chapitre, nous travaillerons sur l'installation de Requests. Pour commencer à travailler avec le module Requests, nous devons d'abord installer Python. Nous allons donc travailler à suivre -
- Installez Python
- Demandes d'installation
Installer Python
Accédez au site officiel de Python: https://www.python.org/downloads/comme indiqué ci-dessous et cliquez sur la dernière version disponible pour Windows, Linux / Unix et Mac OS. Téléchargez Python selon votre système d'exploitation 64 ou 32 bits disponible avec vous.
Une fois que vous avez téléchargé, cliquez sur le fichier .exe et suivez les étapes pour installer python sur votre système.
Le gestionnaire de paquets python, c'est-à-dire pip, sera également installé par défaut avec l'installation ci-dessus. Pour que cela fonctionne globalement sur votre système, ajoutez directement l'emplacement de python à la variable PATH. La même chose est affichée au début de l'installation pour ne pas oublier de cocher la case qui dit AJOUTER au CHEMIN. Si vous oubliez de le vérifier, veuillez suivre les étapes ci-dessous pour l'ajouter à PATH.
Pour ajouter à PATH, suivez les étapes -
Faites un clic droit sur l'icône de votre ordinateur et cliquez sur Propriétés> Paramètres système avancés.
Il affichera l'écran comme indiqué ci-dessous -
Cliquez sur Variables d'environnement comme indiqué ci-dessus. Il affichera l'écran comme indiqué ci-dessous -
Sélectionnez Chemin et cliquez sur le bouton Modifier, ajoutez le chemin de localisation de votre python à la fin. Maintenant, vérifions la version de python.
Vérification de la version python
E:\prequests>python --version
Python 3.7.3
Demandes d'installation
Maintenant que python est installé, nous allons installer Requests.
Une fois python installé, le gestionnaire de paquets python, c'est-à-dire pip, sera également installé. Voici la commande pour vérifier la version de pip.
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)
Nous avons installé pip et la version est 19.1.1. Maintenant, utilisera pip pour installer le module Requests.
La commande est donnée ci-dessous -
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)
Nous avons déjà installé le module, donc dans l'invite de commande, il indique Exigence déjà satisfaite; s'il n'était pas installé, il aurait téléchargé les packages requis pour l'installation.
Pour vérifier les détails du module de requêtes installé, vous pouvez utiliser la commande suivante:
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:
La version du module Requests est 2.22.0.
Python's Requests est une bibliothèque HTTP qui nous aidera à échanger des données entre le client et le serveur. Considérez que vous avez une interface utilisateur avec un formulaire, dans lequel vous devez entrer les détails de l'utilisateur, donc une fois que vous les entrez, vous devez soumettre les données qui ne sont rien d'autre qu'une demande Http POST ou PUT du client au serveur pour enregistrer les données.
Lorsque vous voulez les données, vous devez les récupérer sur le serveur, qui est à nouveau une requête Http GET. L'échange de données entre le client lorsqu'il demande les données et le serveur répondant avec les données requises, cette relation entre le client et le serveur est très importante.
La demande est faite à l'URL fournie et il peut s'agir d'une URL sécurisée ou non sécurisée.
La requête à l'URL peut être effectuée en utilisant GET, POST, PUT, DELETE. La méthode la plus couramment utilisée est la méthode GET, principalement utilisée lorsque vous souhaitez récupérer des données sur le serveur.
Vous pouvez également envoyer des données à l'URL sous forme de chaîne de requête par exemple -
https://jsonplaceholder.typicode.com/users?id=9&username=Delphine
Donc ici, nous transmettons id = 9 et username = Delphine à l'URL. Toutes les valeurs sont envoyées par paire clé / valeur après le point d'interrogation (?) Et plusieurs paramètres sont passés à l'URL séparés par &.
À l'aide de la bibliothèque de requêtes, l'URL est appelée comme suit à l'aide d'un dictionnaire de chaînes.
Dans lequel les données de l'URL sont envoyées sous forme de dictionnaire de chaînes. Si vous voulez passer id = 9 et username = Delphine, vous pouvez faire comme suit -
payload = {'id': '9', 'username': 'Delphine'}
La bibliothèque de requêtes est appelée comme suit -
res = requests.get('https://jsonplaceholder.typicode.com/users', params=payload')
En utilisant POST, nous pouvons faire comme suit -
res = requests.post('https://jsonplaceholder.typicode.com/users', data = {'id':'9', 'username':'Delphine'})
Utilisation de PUT
res = requests.put('https://jsonplaceholder.typicode.com/users', data = {'id':'9', 'username':'Delphine'})
Utiliser DELETE
res = requests.delete('https://jsonplaceholder.typicode.com/users')
La réponse de la requête Http peut être au format texte codé, codé binaire, au format json ou réponse brute. Les détails de la demande et de la réponse sont expliqués en détail dans les chapitres suivants.
Dans ce chapitre, nous allons comprendre comment travailler avec le module de requêtes. Nous examinerons ce qui suit -
- Faire des requêtes HTTP.
- Passer des paramètres aux requêtes HTTP.
Faire des requêtes HTTP
Pour faire une requête Http, nous devons d'abord importer le module de requête comme indiqué ci-dessous -
import requests
Voyons maintenant comment faire un appel à une URL à l'aide du module de requêtes.
Utilisons l'URL− https://jsonplaceholder.typicode.com/users dans le code, pour tester le module Requests.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.status_code)
L'url− https://jsonplaceholder.typicode.com/usersest appelée à l'aide de la méthode requests.get (). L'objet de réponse de l'URL est stocké dans la variable getdata. Lorsque nous imprimons la variable, cela donne le code de réponse 200, ce qui signifie que nous avons obtenu la réponse avec succès.
Production
E:\prequests>python makeRequest.py
<Response [200]>
Pour obtenir le contenu de la réponse, nous pouvons le faire en utilisant getdata.content comme indiqué ci-dessous -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
getdata.content, affichera toutes les données disponibles dans la réponse.
Production
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 }
Passage de paramètres aux requêtes HTTP
Il ne suffit pas de demander l'URL, nous devons également transmettre des paramètres à l'URL.
Les paramètres sont principalement passés sous forme de paire clé / valeur, par exemple -
https://jsonplaceholder.typicode.com/users?id=9&username=Delphine
Donc, nous avons id = 9 et username = Delphine. Voyons maintenant comment passer ces données aux requêtes du module Http.
Exemple
import requests
payload = {'id': 9, 'username': 'Delphine'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users', params=payload)
print(getdata.content)
Les détails sont stockés dans la charge utile de l'objet dans la paire clé / valeur et transmis aux paramètres, dans la méthode get ().
Production
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]'
Nous obtenons maintenant les détails des détails id = 9 et username = Delphine dans la réponse.
Si vous voulez voir, à quoi ressemble l'URL après avoir passé les paramètres, en utilisant l'objet de réponse à l'URL.
Exemple
import requests
payload = {'id': 9, 'username': 'Delphine'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users', params=payload)
print(getdata.url)
Production
E:\prequests>python makeRequest.py
https://jsonplaceholder.typicode.com/users?id=9&username=Delphine
Dans ce chapitre, nous entrerons plus en détail sur la réponse reçue du module requêtes. Nous discuterons des détails suivants -
- Obtenir une réponse
- Réponse JSON
- Réponse RAW
- Réponse binaire
Obtenir une réponse
Nous ferons une requête à l'URL en utilisant la méthode request.get ().
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users');
Le getdata a l'objet de réponse. Il contient tous les détails de la réponse. Nous pouvons obtenir une réponse de 2 manières en utilisant (. Text ) et (. Content ). L'utilisation de response.text vous rendra les données au format texte comme indiqué ci-dessous -
Exemple
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"
}
},
Vous verrez que la réponse est la même, comme elle serait apparue dans le navigateur lorsque vous affichez la source de l'URL comme indiqué ci-dessous -
Vous pouvez également essayer l'URL .html et voir le contenu en utilisant response.text, ce sera le même que le contenu source de l'URL .html dans le navigateur.
Maintenant, essayons response.content pour la même URL et voyons la sortie.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
Production
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
La réponse est donnée en octets. Vous recevrez une lettrebau début de la réponse. Avec le module de requêtes, vous pouvez obtenir l'encodage utilisé et également modifier l'encodage si nécessaire. Par exemple, pour obtenir le codage, vous pouvez utiliser response.encoding.
print(getdata.encoding)
Production
utf-8
Vous pouvez changer le codage comme suit - Vous pouvez utiliser le codage de votre choix.
getdata.encoding = 'ISO-8859-1'
Réponse JSON
Vous pouvez également obtenir la réponse pour la requête Http au format json en utilisant la méthode response.json () comme suit -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.json())
Production
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'}}]
Réponse RAW
Si vous avez besoin de la réponse brute pour l'URL Http, vous pouvez utiliser response.raw, ajoutez également stream=True à l'intérieur de la méthode get comme indiqué ci-dessous -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', stream=True)
print(getdata.raw)
Production
E:\prequests>python makeRequest.py
<urllib3.response.HTTPResponse object at 0x000000A8833D7B70>
Pour lire plus de contenu à partir des données brutes, vous pouvez le faire comme suit:
print(getdata.raw.read(50))
Production
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'
Réponse binaire
Pour obtenir une réponse binaire, nous pouvons utiliser response.content.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
Production
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
La réponse est donnée en octets. Vous recevrez une lettrebau début de la réponse. La réponse binaire est principalement utilisée pour les demandes non textuelles.
Requests - En-têtes de requêtes HTTP
Dans le chapitre précédent, nous avons vu comment faire la demande et obtenir la réponse. Ce chapitre explorera un peu plus la section d'en-tête de l'URL. Donc, nous allons examiner ce qui suit -
- Comprendre les en-têtes de demande
- En-têtes personnalisés
- En-têtes de réponse
Comprendre les en-têtes de demande
Frappez n'importe quelle URL dans le navigateur, inspectez-la et archivez l'onglet réseau de l'outil de développement.
Vous obtiendrez les en-têtes de réponse, les en-têtes de demande, la charge utile, etc.
Par exemple, considérez l'URL suivante -
https://jsonplaceholder.typicode.com/users
Vous pouvez obtenir les détails de l'en-tête comme suit -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', stream=True)
print(getdata.headers)
Production
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'}
Pour lire n'importe quel en-tête http, vous pouvez le faire comme suit -
getdata.headers["Content-Encoding"] // gzip
En-têtes personnalisés
Vous pouvez également envoyer des en-têtes à l'URL appelée comme indiqué ci-dessous.
Exemple
import requests
headers = {'x-user': 'test123'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users', headers=headers)
Les en-têtes transmis doivent être au format chaîne, bytestring ou Unicode. Le comportement de la demande ne changera pas selon les en-têtes personnalisés transmis.
En-têtes de réponse
Les en-têtes de réponse ressemblent à ceux ci-dessous lorsque vous vérifiez l'URL dans l'outil de développement du navigateur, onglet réseau -
Pour obtenir les détails des en-têtes à partir du module de requêtes, utilisez. Les en-têtes de réponse sont comme indiqué ci-dessous -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.headers)
Production
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'}
Vous pouvez obtenir n'importe quel en-tête spécifique que vous voulez comme suit -
print(getdata.headers["Expect-CT"])
Production
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"))
Production
max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/exp
ect-ct
Demandes - Traitement des demandes GET
Ce chapitre se concentrera davantage sur les requêtes GET, qui sont les plus courantes et les plus utilisées. Le fonctionnement de GET dans le module de requêtes est très simple. Voici un exemple simple d'utilisation de l'URL à l'aide de la méthode GET.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
getdata.content, will print all the data available in the response.
Production
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 }
Vous pouvez également passer des paramètres à la méthode get en utilisant l'attribut param comme indiqué ci-dessous -
import requests
payload = {'id': 9, 'username': 'Delphine'}
getdata = requests.get('https://jsonplaceholder.typicode.com/users',
params=payload)
print(getdata.content)
Les détails sont stockés dans la charge utile de l'objet dans la paire clé / valeur et transmis aux paramètres, dans la méthode get ().
Production
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]'
Gestion des requêtes POST, PUT, PATCH et DELETE
Dans ce chapitre, nous allons comprendre comment utiliser la méthode POST à l'aide de la bibliothèque de requêtes et également transmettre des paramètres à l'URL.
Utiliser POST
Pour la requête PUT, la bibliothèque Requests a la méthode requests.post (), l'exemple en est montré ci-dessous:
demandes d'importation
myurl = 'https://postman-echo.com/post'
myparams = {'name': 'ABC', 'email':'[email protected]'}
res = requests.post(myurl, data=myparams)
print(res.text)
Production
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"}
Dans l'exemple ci-dessus, vous pouvez transmettre les données du formulaire en tant que paire clé-valeur au paramètre de données dans requests.post (). Nous verrons également comment travailler avec PUT, PATCH et DELETE dans le module de requêtes.
Utilisation de PUT
Pour la requête PUT, la bibliothèque Requests a la méthode requests.put (), l'exemple en est montré ci-dessous.
import requests
myurl = 'https://postman-echo.com/put'
myparams = {'name': 'ABC', 'email':'[email protected]'}
res = requests.put(myurl, data=myparams)
print(res.text)
Production
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"}
Utilisation de PATCH
Pour la requête PATCH, la bibliothèque Requests a la méthode requests.patch (), dont l'exemple est montré ci-dessous.
import requests
myurl = https://postman-echo.com/patch'
res = requests.patch(myurl, data="testing patch")
print(res.text)
Production
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"}
Utiliser DELETE
Pour la requête DELETE, la bibliothèque Requests dispose de la méthode requests.delete (), dont l'exemple est illustré ci-dessous.
import requests
myurl = 'https://postman-echo.com/delete'
res = requests.delete(myurl, data="testing delete")
print(res.text)
Production
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"}
Demandes - Téléchargement de fichiers
Dans ce chapitre, nous téléchargerons un fichier à l'aide de request et lirons le contenu du fichier téléchargé. Nous pouvons le faire en utilisant lefiles param comme indiqué dans l'exemple ci-dessous.
Nous utiliserons le http://httpbin.org/post pour télécharger le fichier.
Exemple
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
Exemple
var total = [0, 1, 2, 3].reduceRight(function(a, b){ return a + b; });
console.log("total is : " + total );
Production
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"
}
Il est également possible d'envoyer le contenu du fichier comme indiqué ci-dessous -
Exemple
import requests
myurl = 'https://httpbin.org/post'
files = {'file': ('test1.txt', 'Welcome to TutorialsPoint')}
getdata = requests.post(myurl, files=files)
print(getdata.text)
Production
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"
}
Demandes - Utilisation des cookies
Ce chapitre expliquera comment gérer les cookies. Vous pouvez obtenir les cookies ainsi que les envoyer en appelant l'URL en utilisant la bibliothèque de requêtes.
L'url, https://jsonplaceholder.typicode.com/users lorsque le navigateur frappe, nous pouvons obtenir les détails des cookies comme indiqué ci-dessous -
Vous pouvez lire les cookies comme indiqué ci-dessous -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.cookies["__cfduid"])
Production
E:\prequests>python makeRequest.py
d1733467caa1e3431fb7f768fa79ed3741575094848
Vous pouvez également envoyer des cookies lorsque nous faisons une demande.
Exemple
import requests
cookies = dict(test='test123')
getdata = requests.get('https://httpbin.org/cookies',cookies=cookies)
print(getdata.text)
Production
E:\prequests>python makeRequest.py
{
"cookies": {
"test": "test123"
}
}
Demandes - Utilisation des erreurs
Ce chapitre explique comment gérer les erreurs qui surviennent lors de l'utilisation de la bibliothèque de requêtes Http. Il est toujours bon de gérer les erreurs pour tous les cas possibles.
Exception d'erreur
Le module de requêtes donne les types d'exception d'erreur suivants:
ConnectionError- Ce sera déclenché s'il y a une erreur de connexion. Par exemple, le réseau a échoué, erreur DNS afin que la bibliothèque Request lève l'exception ConnectionError.
Response.raise_for_status()- Basé sur le code de statut, c'est-à-dire 401, 404, il déclenchera HTTPError pour l'url demandée.
HTTPError- Cette erreur sera générée pour une réponse invalide provenant de la demande effectuée.
Timeout- Erreurs générées pendant un délai d'expiration pour l'URL demandée.
TooManyRedirects- Si la limite est dépassée pour les redirections maximales, l'erreur TooManyRedirects sera générée.
Exemple
Voici un exemple d'erreurs affichées pour timeout−
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)
Production
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)'))
Requêtes - Gestion des délais d'expiration
Les délais d'expiration peuvent être facilement ajoutés à l'URL que vous demandez. Il se trouve que vous utilisez une URL tierce et attendez une réponse. Il est toujours judicieux de donner un délai d'expiration sur l'URL, car nous souhaitons peut-être que l'URL réponde dans un délai avec une réponse ou une erreur. Si vous ne le faites pas, vous pouvez attendre indéfiniment cette demande.
Nous pouvons donner un délai d'expiration à l'URL en utilisant le paramètre timeout et la valeur est passée en secondes comme indiqué dans l'exemple ci-dessous -
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
print(getdata.text)
Production
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)'))
Le délai imparti est le suivant:
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=0.001)
L'exécution lève une erreur de délai de connexion comme indiqué dans la sortie. Le délai imparti est de 0,001, ce qui n'est pas possible pour la demande de récupérer la réponse et génère une erreur. Maintenant, nous allons augmenter le délai et vérifier.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users',timeout=1.000)
print(getdata.text)
Production
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"
}
Avec un timeout de 1 seconde, nous pouvons obtenir la réponse pour l'URL demandée.
Requêtes - Gestion de la redirection
Ce chapitre examinera comment la bibliothèque Request gère le cas de redirection d'url.
Exemple
import requests
getdata = requests.get('http://google.com/')
print(getdata.status_code)
print(getdata.history)
L'url− http://google.com sera redirigé à l'aide du code d'état 301 (déplacé définitivement) vers https://www.google.com/. La redirection sera enregistrée dans l'historique.
Production
Lorsque le code ci-dessus est exécuté, nous obtenons le résultat suivant -
E:\prequests>python makeRequest.py
200
[<Response [301]>]
Vous pouvez arrêter la redirection d'une URL en utilisant allow_redirects=False. Cela peut être fait sur les méthodes GET, POST, OPTIONS, PUT, DELETE, PATCH utilisées.
Exemple
Voici un exemple sur le même.import requests
getdata = requests.get('http://google.com/', allow_redirects=False)
print(getdata.status_code)
print(getdata.history)
print(getdata.text)
Maintenant, si vous vérifiez la sortie, la redirection ne sera pas autorisée et obtiendra un code d'état 301.
Production
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>
Demandes - Historique de gestion
Vous pouvez obtenir l'historique d'une URL donnée en utilisant response.history. Si l'URL donnée a des redirections, celles-ci seront stockées dans l'historique.
Pour l'histoire
import requests
getdata = requests.get('http://google.com/')
print(getdata.status_code)
print(getdata.history)
Production
E:\prequests>python makeRequest.py
200
[<Response [301]>]
le response.historyproperty aura les détails des objets de réponse qui ont été effectués en fonction de la demande. Les valeurs présentes seront triées de la plus ancienne à la plus récente. leresponse.history property suit toute la redirection effectuée sur l'URL demandée.
Demandes - Traitement des sessions
Pour conserver les données entre les demandes, vous avez besoin de sessions. Ainsi, si le même hôte est appelé encore et encore, vous pouvez réutiliser la connexion TCP qui à son tour améliorera les performances. Voyons maintenant comment conserver les cookies à travers les demandes effectuées à l'aide de sessions.
Ajouter des cookies en utilisant une session
import requests
req = requests.Session()
cookies = dict(test='test123')
getdata = req.get('https://httpbin.org/cookies',cookies=cookies)
print(getdata.text)
Production
E:\prequests>python makeRequest.py
{
"cookies": {
"test": "test123"
}
}
À l'aide de session, vous pouvez conserver les données des cookies à travers les demandes. Il est également possible de passer des données d'en-têtes en utilisant la session comme indiqué ci-dessous.
Exemple
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)
Demandes - Certification SSL
Le certificat SSL est une fonctionnalité de sécurité fournie avec des URL sécurisées. Lorsque vous utilisez la bibliothèque Requests, elle vérifie également les certificats SSL pour l'URL https donnée. La vérification SSL est activée par défaut dans le module de requêtes et générera une erreur si le certificat n'est pas présent.
Travailler avec une URL sécurisée
Voici l'exemple de travail avec une URL sécurisée -
import requests
getdata = requests.get(https://jsonplaceholder.typicode.com/users)
print(getdata.text)
Production
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"
}
}
]
Nous obtenons facilement une réponse de l'URL https ci-dessus, et c'est parce que le module de requête peut vérifier le certificat SSL.
Vous pouvez désactiver la vérification SSL en ajoutant simplement verify = False comme indiqué dans l'exemple ci-dessous.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', verify=False)
print(getdata.text)
Vous obtiendrez la sortie, mais cela donnera également un message d'avertissement indiquant que le certificat SSL n'est pas vérifié et qu'il est conseillé d'ajouter une vérification de certificat.
Production
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"
}
}
]
Vous pouvez également vérifier le certificat SSL en l'hébergeant à votre extrémité et en indiquant le chemin en utilisant verify param comme indiqué ci-dessous.
Exemple
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', verify='C:\Users\AppData\Local\certificate.txt')
print(getdata.text)
Production
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"
}
}
]
Demandes - Authentification
Ce chapitre abordera les types d'authentification disponibles dans le module Requêtes.
Nous allons discuter de ce qui suit -
Fonctionnement de l'authentification dans les requêtes HTTP
Authentification de base
Authentification Digest
Authentification OAuth2
Fonctionnement de l'authentification dans les requêtes HTTP
L'authentification HTTP est du côté serveur demandant des informations d'authentification comme le nom d'utilisateur, le mot de passe lorsque le client demande une URL. Il s'agit d'une sécurité supplémentaire pour la demande et la réponse échangées entre le client et le serveur.
Du côté client, ces informations d'authentification supplémentaires, c'est-à-dire le nom d'utilisateur et le mot de passe, peuvent être envoyées dans les en-têtes, qui seront ensuite validés côté serveur. La réponse sera délivrée du côté serveur uniquement lorsque l'authentification est valide.
La bibliothèque Requests a l'authentification la plus couramment utilisée dans requests.auth , qui sont l'authentification de base ( HTTPBasicAuth ) et l'authentification Digest ( HTTPDigestAuth ).
Authentification de base
Il s'agit de la forme la plus simple de fournir une authentification au serveur. Pour travailler avec l'authentification de base, nous allons utiliser la classe HTTPBasicAuth disponible avec la bibliothèque de requêtes.
Exemple
Voici un exemple pratique de son utilisation.
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)
Nous appelons l'url, https://httpbin.org/basic-auth/admin/admin123avec l'utilisateur comme admin et le mot de passe comme admin123 .
Donc, cette URL ne fonctionnera pas sans authentification, c'est-à-dire utilisateur et mot de passe. Une fois que vous avez donné l'authentification à l'aide du paramètre auth, seul le serveur rendra la réponse.
Production
E:\prequests>python makeRequest.py
{
"authenticated": true,
"user": "admin"
}
Authentification Digest
Il s'agit d'une autre forme d'authentification disponible avec les demandes. Nous allons utiliser la classe HTTPDigestAuth à partir des requêtes.
Exemple
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)
Production
E:\prequests>python makeRequest.py
{
"authenticated": true,
"user": "admin"
}
Authentification OAuth2
Pour utiliser l'authentification OAuth2, nous avons besoin de la bibliothèque «requests_oauth2». Pour installer «requests_oauth2», procédez comme suit -
pip install requests_oauth2
L'affichage dans votre terminal lors de l'installation sera quelque chose comme indiqué ci-dessous -
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
Nous avons fini d'installer «requests-oauth2». Pour utiliser les API de Google, Twitter, nous avons besoin de son consentement et la même chose est faite en utilisant l'authentification OAuth2.
Pour l'authentification OAuth2, nous aurons besoin d'un ID client et d'une clé secrète. Les détails sur la façon de l'obtenir sont mentionnés surhttps://developers.google.com/identity/protocols/OAuth2.
Plus tard, connectez-vous à Google API Console, disponible sur https://console.developers.google.com/et récupérez l'identifiant du client et la clé secrète.
Exemple
Voici un exemple d'utilisation de "requests-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)
Nous ne pourrons pas rediriger vers l'URL donnée, car elle doit se connecter au compte Gmail, mais ici, vous verrez à partir de l'exemple, que google_auth fonctionne et que l'URL autorisée est donnée.
Production
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
Demandes - Hooks d'événement
Nous pouvons ajouter des événements à l'URL demandée à l'aide de hooks d'événement. Dans l'exemple ci-dessous, nous allons ajouter une fonction de rappel qui sera appelée lorsque la réponse sera disponible.
Exemple
Pour ajouter le rappel, nous devons utiliser le paramètre de hooks comme indiqué dans l'exemple ci-dessous -
mport requests
def printData(r, *args, **kwargs):
print(r.url)
print(r.text)
getdata = requests.get('https://jsonplaceholder.typicode.com/users',
hooks={'response': printData})
Production
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"
}
}
]
Vous pouvez également appeler plusieurs fonctions de rappel comme indiqué ci-dessous -
Exemple
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]})
Production
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"
}
}
]
Vous pouvez également ajouter le hook à la session créée comme indiqué ci-dessous -
Exemple
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')
Production
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"
}
}
]
Demandes - Proxy
Jusqu'à présent, nous avons vu des clients se connecter et parler directement au serveur. En utilisant un proxy, l'interaction se déroule comme suit -
Le client envoie une demande au proxy.
Le proxy envoie la demande au serveur.
Le serveur renvoie la réponse au proxy.
Le proxy renverra une réponse au client.
L'utilisation de Http-proxy est une sécurité supplémentaire attribuée pour gérer l'échange de données entre le client et le serveur. Les bibliothèques de requêtes ont également la possibilité de gérer le proxy, en utilisant le paramètre proxy comme indiqué ci-dessous.
Exemple
import requests
proxies = {
'http': 'http://localhost:8080'
}
res = requests.get('http://httpbin.org/', proxies=proxies)
print(res.status_code)
La demande sera acheminée vers ('http://localhost:8080 URL.
Production
200
Requêtes - Web Scraping à l'aide de requêtes
Nous avons déjà vu comment obtenir des données à partir d'une URL donnée à l'aide de la bibliothèque de requêtes python. Nous essaierons de supprimer les données du site deTutorialspoint qui est disponible à https://www.tutorialspoint.com/tutorialslibrary.htm en utilisant ce qui suit -
Bibliothèque de demandes
Belle bibliothèque de soupe de python
Nous avons déjà installé la bibliothèque Requests, installons maintenant le package Beautiful soup. Voici le site officiel debeautiful soup disponible à https://www.crummy.com/software/BeautifulSoup/bs4/doc/ au cas où vous voudriez explorer d'autres fonctionnalités de la belle soupe.
Installation de Beautifulsoup
Nous verrons comment installer Beautiful Soup ci-dessous -
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
Nous avons maintenant une bibliothèque de requêtes python et une belle soupe installée.
Écrivons maintenant le code, qui supprimera les données de l'URL donnée.
Grattage Web
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'))
En utilisant la bibliothèque de requêtes, nous pouvons récupérer le contenu de l'URL donnée et une belle bibliothèque de soupe aide à l'analyser et à récupérer les détails comme nous le souhaitons.
Vous pouvez utiliser une belle bibliothèque de soupe pour récupérer des données à l'aide de la balise Html, de la classe, de l'identifiant, du sélecteur css et de bien d'autres façons. Voici la sortie que nous obtenons dans laquelle nous avons imprimé le titre de la page ainsi que toutes les balises h4 de la page.
Production
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>]