Différences
Ci-dessous, les différences entre deux révisions de la page.
| Les deux révisions précédentes Révision précédente Prochaine révision | Révision précédente | ||
| web:api [2023/03/06 11:16] – [Principes REST] jcheron | web:api [2023/04/25 02:42] (Version actuelle) – [Liens] jcheron | ||
|---|---|---|---|
| Ligne 33: | Ligne 33: | ||
| **Affichage d'un client** | **Affichage d'un client** | ||
| <sxh ; | <sxh ; | ||
| - | NOK : https:// | + | NOK : https:// |
| OK : https:// | OK : https:// | ||
| </ | </ | ||
| Ligne 82: | Ligne 82: | ||
| OK : DELETE https:// | OK : DELETE https:// | ||
| </ | </ | ||
| + | |||
| + | === 3 - Représentation de ressources === | ||
| + | |||
| + | La réponse HTTP reçue est une représentation de ressource, et non la ressource elle même : | ||
| + | |||
| + | En fonction de la requête effectuée et de son en-tête **Accept**, plusieurs formmats de réponses sont envisageables : | ||
| + | * JSON | ||
| + | * XML | ||
| + | * HTML | ||
| + | * CSV | ||
| + | * etc... | ||
| + | |||
| + | **Exemple** | ||
| + | |||
| + | <sxh ; | ||
| + | GET /clients | ||
| + | Host: myapi.com | ||
| + | Accept: application/ | ||
| + | </ | ||
| + | |||
| + | |||
| + | === 4 - Liens = relation entre ressources === | ||
| + | Les liens d'une ressource indiquent les relations qu' | ||
| + | L’IANA donne une liste de relation parmi lesquelles : | ||
| + | |||
| + | * contents | ||
| + | * edit | ||
| + | * next | ||
| + | * last | ||
| + | * payment | ||
| + | * etc... | ||
| + | |||
| + | [[https:// | ||
| + | |||
| + | === 5 - Authentification par jeton === | ||
| + | |||
| + | REST étant par principe **stateless** (pas de session HTTP par exemple), l' | ||
| + | |||
| + | Chaque requête est envoyée avec un jeton (token) passé en paramètre **GET** de la requête ou dans les headers. Ce jeton temporaire est obtenu en envoyant une première requête d’authentification puis en le combinant avec les requêtes. | ||
| + | |||
| + | [[https:// | ||
| + | |||
| + | ===== Liens ===== | ||
| + | * [[https:// | ||
| + | * [[https:// | ||
| + | * [[https:// | ||
| + | * [[https:// | ||
| + | * [[https:// | ||
| + | |||