* Un espace de noms (namespace) permet de distinguer différentes familles de noms de balises
* xmlns désigne un identifiant (URI), pas nécessairement un fichier
* http://www.w3.org/svg IMAGE n’est pas disponible.
Espace de nom et shéma
Grammaire définie dans un XML Schema (XSD).
CODE
Constraints : RP2
The representation of a resource is a sequence of bytes, plus representation metadata [..]. The particular form of the representation can be negotiated [..]
# Rappel HTTP : Accept, MIME
* Accept
* L’entête HTTP porte les représentations exploitables par le client * Exemple : text/vcard (text/vcard deprecated)
* type MIME * Content-type: type_mime_principal/sous_type_mime * Exemple : image GIF : * Content-type: image/gif * Référentiel des types MIME * http://www.iana.org/assignments/media-types/index.html
Constraints : RP3
All interactions are context-free – each interaction contains all the information necessary to understand the request, independent of any requests that may have preceded.
Etat sous toutes les coutures (1)
Lutter contre les abus de languages
Terminologie
State
a set of attributes belonging to an entity with a given value
Session
series of related messages
Interaction
échange d’un seul message
# Etat sous toutes les coutures (2)
* Type d’états * Session state * "Session state" refers to the state which identifies where in the series of messages a client currently is * Application State * information necessary to understand the context of an interaction * Axiomes * all messages (requests) must include all session state
Contre-ex : stateful interaction
Frank = client / Bob = Server
Frank > I would like your phone number, plz.
Bob > Who are you?
Frank > I'm your old buddy Frank, don't you recognize me ?
Bob > Oh, well then my number is 112.
Extrait de http://rest.blueoxen.net/
Constraints : RP4
Components perform only a small set of well-defined methods on a resource producing a representation to capture the current or intended state of that resource [..]
These methods are global to the specific architectural instantiation of REST (namely HTTP on the WWW)
De pensez objet à pensez ressources
IMAGE
# Les méthodes HTTP * Demander une ressource * GET : rapatrier une ressource * POST : envoyer des données et rapatrier une ressource * Avoir de l’information sur une ressource * HEAD : connaître ses caractéristiques * OPTIONS : connaître les options qui lui sont applicables * Mettre à jour une ressource à distance * PUT : la créer ou remplacer son contenu * DELETE : la détruire
# HTTP – codes retour
* 100 Continue * 101 Switching Protocols * 200 OK * 201 Created * 202 Accepted * 203 Non-Authorative * 204 No Content * 205 Reset Content * 206 Partial Content * 300 Multiples Choices * 301 Moved Permanently * 302 Found * 303 See Other * 304 Not Modified * 305 Use Proxy * 307 Temporary Redirect * 400 Bad Request * 401 Unauthorized * 402 Payment Required * 403 Forbidden * 404 Not Found * 405 Method Not Allowed * 406 Not Acceptable * 407 Proxy Authentication Required * 408 Request Timeout * 409 Conflict * 410 Gone * 411 Length Required * 412 Precondition Failed * 413 Request Entity Too Large * 414 Request-URI Too Long * 415 Unsupported Media Type * 416 Requested Range Not Satisfiable * 417 Expectation Failed * 500 Internal Server Error * 501 Not Implemented * 502 Bad Gateway * 503 Service Unavailable * 504 Gateway Timeout * 505 HTTP Version Not Supported
Constraints : RP5
Idempotent operations and representation meta-data are encouraged in support of caching and representation reuse
Rappel : verbes HTTP
Safe
GET and HEAD
Idempotent
GET, HEAD, PUT and DELETE
Non idempotent AND Non-safe
POST
Commentaire
Constraints : RP6
The presence of intermediaries is promoted [..]
ETag
IMAGE
REST et Cache
Rappel : HTTP dispose d’un champ Cacheable
IMAGE
Méthode de conception
Quels sont les ressources (URI) ?
Format d’échange (XML, HTML, …)
Le protocole est TOUJOURS HTTP en REST
Méthode (au sens HTTP) supportée par chaque URI
Code de statut renvoyé
Artefact de conception
TABLEAU
Extrait de : http://www.la-grange.net/2005/05/rest/restful-web-01.html
Conclusion : principes
* Protocole client / serveur
* Les interactions sont sans état (stateless) et sans connexion
* Les ressources sont identifiées par des URI (une URL est un type d’URI)
* Média échangé de type MIME
Conclusion : règles de REST
Pour respecter ces contraintes, REST fixe des règles:
Les ressources sont manipulées par leur représentation
Les messages échangés sont auto-descriptifs
Difficulté
Ce sont des conventions, que doit s’imposer le codeur responsable
Adaptation aux volumes
Le style REST permet de monter en puissance aussi bien :
du côté client
Un client tiers peut venir à la rescousse pour traiter une transition (exemple chercher code postal)
que du côté serveur
Dans la mesure où tout est exprimé sous forme d’URL, un serveur tiers peut récupérer l’état en copiant toutes les URLs de l’échange.