technique:python:api_python

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Dernière révisionLes deux révisions suivantes
technique:python:api_python [2020/06/26 15:36] francoisatechnique:python:api_python [2023/02/14 20:55] francoisa
Ligne 109: Ligne 109:
 } }
  
 +
 +</code>
 +
 +===== Cas de l'API de Garradin =====
 +
 +Pour utiliser l'[[https://fossil.kd2.org/garradin/wiki?name=API|API de Garradin]], on peut tester avec curl en utilisant l'option "''curl –trace-ascii -''" pour voir le contenu des échanges :
 +<code>
 +
 +=> Send header, 233 bytes (0xe9)
 +0000: POST /api/sql/ HTTP/1.1
 +0019: Host: assos-zourit-net.garradin.eu
 +003d: Authorization: Basic XXXX
 +007c: User-Agent: curl/7.81.0
 +0095: Accept: */*
 +00a2: Content-Length: 50
 +00b6: Content-Type: application/x-www-form-urlencoded
 +00e7:
 +=> Send data, 50 bytes (0x32)
 +0000: SELECT * FROM membres where domaine LIKE "%peak%";
 +
 +</code>
 +
 +La requête en python doit passer en mode POST (selon la doc) et utiliser l'option "data" pour passer le contenu exact de la requête en mode POST.
 +
 +En mode GET, utiliser l'options "params".
 +
 +<code>
 +import requests
 +from requests.auth import HTTPBasicAuth
 +URL='https://assos-zourit-net.garradin.eu/api/sql/'
 +
 +reponse = requests.post(URL,auth=HTTPBasicAuth('userapi', 'motdepasseAPI'),data='SELECT * FROM membres where domaine LIKE "%truc%";')
 +print(reponse.json())
 +
 +</code>
 +
 +On peut utiliser la methode ''prepare()'' pour voir le contenu exact des datas envoyés :
 +<code>
 +prepared = requests.Request('POST',URL,auth=HTTPBasicAuth('XX', 'XX'),data={'q': 'SELECT * FROM membres where domaine LIKE "%peak%";'}).prepare()
 +print(prepared.body)
  
 </code> </code>
Ligne 134: Ligne 174:
 </code> </code>
  
-Voir la doc complète https://httpie.org/docs#json par exemple :+Voir la doc complète [[https://httpie.org/docs#json|https://httpie.org/docs#json]] par exemple :
  
-<lang-bash has-termible>+<code bash>
 echo '{"hello": "world"}' | http POST monurl.org/post echo '{"hello": "world"}' | http POST monurl.org/post
  
-</lang-bash>+ 
 +</code> 
 +===== Utilisation de json dans une requête sur une API avec un json complexe en python ===== 
 + 
 +Exemple avec petit-rapporteur : 
 +<code> 
 + 
 +jsontext = """
 +    "comment": "CPO EN 2023 v2 - Accès MONAT", 
 +    "policies":
 +    { 
 +        "report_id": "MONRAPPORT", 
 +        "field_id": "*", 
 +        "actions":
 +          "report:read", 
 +          "report:write" 
 +        ], 
 +        "filters":
 +            { 
 +            "field_name": "AT", 
 +            "field_data": "MONAT" 
 +            } 
 +        ] 
 +    } 
 +    ] 
 +    }""" 
 + 
 +</code> 
 + 
 +Et la requête : 
 + 
 +<code> 
 +r = requests.post(apiurl, json=json.loads(jsontext), headers=headers) 
 +print(r.text) 
 +data = r.json() 
 + 
 +</code> 
 + 
 +json.loads : transforme une string au format long en format json.
  
  
  • technique/python/api_python.txt
  • Dernière modification : 2024/04/02 15:08
  • de 127.0.0.1