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 Prochaine révisionLes deux révisions suivantes | ||
reseaux:internet:rest [2021/11/11 10:00] – [Le modèle client-serveur du Web] phil | reseaux:internet:rest [2022/08/06 08:53] – [3. Serveur sans état] phil | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
[[reseaux: | [[reseaux: | ||
- | ===== REST - Le nommage | + | ===== L' |
{{ : | {{ : | ||
[Mise à jour le 11/11/2021] | [Mise à jour le 11/11/2021] | ||
Ligne 9: | Ligne 9: | ||
* **Vidéo** sur YouTube: < | * **Vidéo** sur YouTube: < | ||
- | ==== Le modèle client-serveur du Web ==== | + | ==== 1. Le modèle client-serveur du Web ==== |
{{ : | {{ : | ||
Le Web et ses extensions sont basés sur un **modèle client-serveur**. Les serveurs possèdent des ressources et les clients peuvent y accéder ou les modifier grâce à un protocole tel que HTTP. Le **modèle client-serveur** est quelque chose de courant dans les réseaux informatiques, | Le Web et ses extensions sont basés sur un **modèle client-serveur**. Les serveurs possèdent des ressources et les clients peuvent y accéder ou les modifier grâce à un protocole tel que HTTP. Le **modèle client-serveur** est quelque chose de courant dans les réseaux informatiques, | ||
Ligne 23: | Ligne 23: | ||
* **système en couches** : cela signifie que les services peuvent être réalisés en utilisant des couches telles que différents serveurs responsables de différentes parties de services (stockage, recherche, etc.), mais le client ne sait pas s’il est connecté au serveur final ou intermédiaire. | * **système en couches** : cela signifie que les services peuvent être réalisés en utilisant des couches telles que différents serveurs responsables de différentes parties de services (stockage, recherche, etc.), mais le client ne sait pas s’il est connecté au serveur final ou intermédiaire. | ||
* **code à la demande** (facultatif) : les serveurs peuvent éventuellement envoyer du code exécutable aux clients. | * **code à la demande** (facultatif) : les serveurs peuvent éventuellement envoyer du code exécutable aux clients. | ||
- | * **interface uniforme** : elle fait référence aux principes selon lesquelles une ressource doit avoir une seule représentation telle que les URI (Uniform Resource Identifier), et suivre certaines directives pour la dénomination, | + | * **interface uniforme** : elle fait référence aux principes selon lesquelles une ressource doit avoir une seule représentation telle que les **URI** (**U**niform **R**esource **I**dentifier), et suivre certaines directives pour la dénomination, |
- | Le respect de ces règles permet l’évolutivité du système en ajoutant continuellement des acteurs et de nouvelles données. L’objectif principal est de simplifier le comportement du serveur afin de servir le plus grand nombre de requêtes possible. | + | |
+ | <callout type=" | ||
+ | |||
+ | ==== 2. Le nommage ==== | ||
+ | < | ||
+ | |||
+ | Les URI permettent de désigner une ressource de manière non ambigüe, c' | ||
+ | |||
+ | <callout type=" | ||
+ | |||
+ | Par **exemple**, | ||
+ | |||
+ | * " | ||
+ | |||
+ | mais il y a peu de chance que ce nom soit unique, d' | ||
+ | |||
+ | * 33667789078image | ||
+ | |||
+ | qui sera unique si je ne nomme qu'une seule ressource " | ||
+ | |||
+ | * 33667239018image | ||
+ | |||
+ | sans ambiguïté possible. Cependant, comme le numéro de téléphone est unique dans l' | ||
+ | |||
+ | Pour éviter les conflits, il est intéressant de donner, au début l' | ||
+ | |||
+ | * tel: | ||
+ | |||
+ | et | ||
+ | |||
+ | * ss: | ||
+ | |||
+ | On aura donc deux identifiants uniques, même si le hasard a fait que ce numéro de téléphone et ce numéro de sécurité sociale coïncident. | ||
+ | |||
+ | Les URI formalisent ce principe. Le [RFC 3986] explique comment ils peuvent être construits. | ||
+ | |||
+ | <note warning> | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | Par **exemple** : | ||
+ | * < | ||
+ | * < | ||
+ | * < | ||
+ | |||
+ | Ainsi, si je mets une ressource sur mon site Web, celui-ci est identifié par un **nom de domaine**, par exemple example.com. Je suis propriétaire de ce nom. Je peux donc l’utiliser pour identifier de manière unique ma ressource. Si on reprend le principe de construction d’un URI, j’aurai : | ||
+ | |||
+ | * < | ||
+ | |||
+ | Personne d’autre dans l’univers ne pourra identifier ses ressources avec cette chaîne de caractères puisque // | ||
+ | |||
+ | <note warning> | ||
+ | |||
+ | L’URI a pour but de facilement nommer une ressource, de pouvoir lier les ressources entre elles pour former cette toile d’araignée mondiale. Le schéma définit à la fois l' | ||
+ | |||
+ | <note important> | ||
+ | |||
+ | Le schéma HTTP est pratique, car il peut se lire également comme un URL. Ce schéma donne : | ||
+ | |||
+ | * le **protocole** à utiliser pour accéder à la ressource (HTTP), | ||
+ | * l’**autorité** qui indique l’**adresse du serveur** (et son **port**), et enfin, | ||
+ | * le **chemin d’accès** de ce que l'on va demander au serveur et qui peut parfois correspondre à une arborescence de fichiers sur un serveur. | ||
+ | |||
+ | ==== 3. Serveur sans état ==== | ||
+ | <callout type=" | ||
+ | |||
+ | Cela impose que l’état soit situé du côté du client. Cet état est alimenté à partir des données structurées que le client reçoit du serveur. Ainsi, lorsqu’un client demande une page Web, celle-ci peut contenir d’autres URI pour la compléter, par exemple des images, des feuilles de style, des scripts, etc. | ||
+ | |||
+ | Le client doit donc comprendre les données que le serveur lui envoie et donc connaître le format de représentation de la ressource qu'il reçoit pour y retrouver les URI. Donc, **en plus de la ressource elle-même, le serveur ajoute des informations complémentaires, | ||
+ | |||
+ | HTTP est un protocole qui peut être utilisé pour mettre en œuvre un serveur Web en appliquant les principes de REST (qualifié en anglais de < | ||
+ | |||
+ | HTTP définit différentes **méthodes** permettant au client d’interagir avec les ressources sur le serveur : | ||
+ | |||
+ | * **GET** est utilisée pour récupérer la représentation d’une ressource (par exemple page Web, valeur de température d’un capteur, etc.). Par exemple, la figure ci-dessous donne le format d’en-tête HTTP GET pour récupérer ma page Web : | ||
+ | {{ : | ||
+ | |||
+ | * **HEAD** est utilisée pour récupérer uniquement les métadonnées présentes dans les en-têtes de réponse sans le corps de réponse ; | ||
+ | |||
+ | * **POST** est utilisée pour indiquer au serveur une nouvelle ressource | ||
+ | |||
+ | * **PUT** est utilisée pour stocker une ressource à l’endroit identifié par l’URI dans la requête. Si la ressource existe déjà, elle sera modifiée ; | ||
+ | |||
+ | * **PATCH** permet au client de ne modifier qu’une partie de la ressource ; | ||
+ | |||
+ | * **DELETE** est utilisée pour supprimer la ressource définie. |