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>]