SlideShare una empresa de Scribd logo
1 de 134
http://membres-liglab.imag.fr/donsez/cours

Le protocole HTTP

Didier DONSEZ
Université Joseph Fourier (Grenoble 1)
PolyTech’Grenoble – LIG/ADELE
Didier.Donsez@imag.fr
Didier.Donsez@ieee.org
01/01/2010

Au sommaire

>
>
>

Didier Donsez, 1995-2010, HTTP

Historique
Le protocole HTTP
Les méthodes GET et POST
Le suivi de session
Clients et Serveurs HTTP
Autour d ’HTTP

2
01/01/2010

Le Protocole HTTP
HTTP : HyperText Tranfert Protocol (RFC 1945 et 2068)
protocole de rapatriement des documents
protocole de soumission de formulaires

Fonctionnement (très simple en HTTP/1.0)

Didier Donsez, 1995-2010, HTTP

connexion
demande (GET) d ’un document
renvoi du document (status=200) ou d ’une erreur
déconnexion

Cependant
dialogue plus complexe en cas d ’identification
optimisation :
une série de plusieurs requêtes sur une connexion
Connexion « KeepAlive » de HTTP/1.1 (RFC 2068)
3
01/01/2010

Un protocole omniscient
IT Servers

Didier Donsez, 1995-2010, HTTP

Embedded Servers

4
01/01/2010

Dialogue HTTP
Protocole en mode de lignes de caractère
le plus basic de butineur (User Agent) HTTP :
telnet www.sun.com 80

Types de dialogue
Récupération d ’un document
méthode GET

Didier Donsez, 1995-2010, HTTP

Soumission d ’un formulaire
méthodes GET ou POST

Envoi de Document et Gestion de Site
méthodes PUT, DELETE, LINK, UNLINK

Gestion de proxy/cache
méthode HEAD (récupération des informations sur le document)
5
01/01/2010

Dialogue HTTP
exemple de requête HTTP (méthode
POST)
Entête de la
requête

POST /script
UA

Didier Donsez, 1995-2010, HTTP

le Client envoie la Requête

HTTPD
port
80 machX

doc.htm

POST /script HTTP/1.0
méthode,chemin,version
Accept: www/source
documents acceptés
Accept: text/html
le Serveur retourne la Réponse
Accept: image/gif
HTTP/1.0 200 OK ligne de status
Entête de la
Accept: image/jpeg
Date: Wed, 02Feb97 23:04:12 GMT
réponse
User-Agent: Lynx/2.2 libwww/2.14 Server: NCSA/1.1
* une ligne blanche *
MIME-version: 1.0
name1=value1&
Last-modified: Mon,15Nov96 23:33:16 GMT
name2=value2
Content-type: text/html
type du document retourné
Content-length: 2345
sa taille
Corps de la
Corps de la
* une ligne blanche *
réponse
requête
<HTML><HEAD><TITLE> ...

6
01/01/2010

Format de la requête
Envoyé par le client au serveur

Didier Donsez, 1995-2010, HTTP

<Méthode> <URI> HTTP/<Version>
[<Champ d ’entête>: <Valeur>]
[<tab><Suite Valeur si >1024>]
ligne blanche
[corps de la requête pour la méthode POST]
GET /docu2.html HTTP/1.0
Accept: www/source
Accept: text/html
Accept: image/gif
User-Agent: Lynx/2.2 libwww/2.14
From: alice@pays.merveilles.net
* une ligne blanche *

POST /script HTTP/1.0
Accept: www/source
Accept: text/html
Accept: image/gif
User-Agent: Lynx/2.2 libwww/2.14
From: alice@pays.merveilles.net
Content-Length: 24
* une ligne blanche *
name1=value1&
name2=value2

7
01/01/2010

Méthodes de la requête (i)
GET
demande pour obtenir des informations et une zone de données
concernant l ’URI

HEAD
demande pour seulement obtenir des informations concernant
l ’URI

POST

Didier Donsez, 1995-2010, HTTP

envoie de données (contenu du formulaire vers le serveur, requête
SOAP …) situées dans le corps.

PUT
enregistrement du corps de la requête à l ’URI indiqué

DELETE
suppression des données désignées par l ’URI
8
01/01/2010

Méthodes de la requête (ii)
OPTIONS
demande des options de communication disponibles

TRACE
retourne le corps de la requête intacte (déboguage)

CONNECT

Didier Donsez, 1995-2010, HTTP

+ Nouvelles extensions de WebDAV

>

PROPFIND, PROPPATCH, MKCOL,COPY, MOVE, LOCK, UNLOCK

+ Nouvelles extensions de HTTP/U et HTTP/MU
NOTIFY, … (UPnP)

9
01/01/2010

Format de la réponse

Didier Donsez, 1995-2010, HTTP

Réponse envoyé par le serveur au client
HTTP/<Version> <Status> <Commentaire Status>
Content-Type: <Type MIME du contenu>
[< Champ d ’entête >: <Valeur>]
[<tab><Suite Valeur si >1024>]
Ligne blanche
HTTP/1.0 200 OK
Document

Date: Wed, 02Feb97 23:04:12 GMT
Server: NCSA/1.1
MIME-version: 1.0
Last-modified: Mon,15Nov96 23:33:16 GMT
Content-type: text/html
Content-length: 2345
* une ligne blanche *
<HTML><HEAD><TITLE> …
</BODY></HTML>

10
01/01/2010

Status des réponses HTTP (RFC2068)
Code de réponse donné par le serveur au client
100-199
Informationnel
100 : Continue (le client peut envoyer la suite de la requête), ...

200-299

Succès de la requête client

200: OK, 201: Created, 204 : No Content, ...

300-399

Redirection de la Requête client

Didier Donsez, 1995-2010, HTTP

301: Redirection, 302: Found, 304: Not Modified, 305 : Use Proxy, ...

400-499

Requête client incomplète

400: Bad Request, 401: Unauthorized, 403: Forbidden, 404: Not Found

500-599

Erreur Serveur

500: Server Error, 501: Not Implemented,
502: Bad Gateway, 503: Out Of Resources (Service Unavailable)
11
01/01/2010

Entêtes HTTP
4 types de champs d ’entête
Général
commun au serveur, au client ou à HTTP

Requête du client
formats de documents et paramètres pour le serveur

Réponse du serveur
information concernant le serveur
Didier Donsez, 1995-2010, HTTP

Entité
informations concernant les données échangés

12
01/01/2010

Entêtes Généraux HTTP
Cache-Control = contrôle du caching.
Connection = listes d ’option

Didier Donsez, 1995-2010, HTTP

close pour terminer une connexion.

Date = date actuelle (format RFC1123 mais aussi
RFC850).
MIME-Version = version MIME utilisé.
Pragma = instruction pour le proxy.
Transfer-Encoding = type de la transformation appliquée
au corps du message.
Upgrade = indique le protocole souhaité.
Via = utilisé par les proxys pour indiquer les machines et
protocoles intermédiaires.
13
01/01/2010

Entêtes de requêtes client HTTP
Accept = type MIME visualisable par l ’agent
Accept-Language : liste de langues (fr, en, … )
Authorization = type d ’autorisation
BASIC nom:mot de passe (en base64) donc transmis en clair !!!
NB : Préalablement le serveur a répondu un WWW-Authenticate

Cookie = cookie rétourné
Host = spécifie la machine et le port du serveur
Didier Donsez, 1995-2010, HTTP

un serveur peut héberger plusieurs serveurs

Referer = URL d ’origine
page à contenant l ’ancre à partir de laquelle le visualisateur a
trouvé l ’URL.

User-Agent = modèle du visualisateur
14
01/01/2010

Entêtes de requêtes client HTTP
From = adresse email de l ’utilisateur
rarement envoyé pour conserver l anonymat de
l ’utilisateur

If-Modified-Since = condition de retrait

Didier Donsez, 1995-2010, HTTP

la page n ’est transférée que si elle a été modifiée
depuis la date précisée. Utilisé par les caches
indique si le document demandé peut être caché ou
pas.

If-Unmodified-Since = condition de retrait
If-Match = condition de retrait
If-None-Match = condition de retrait
If-Range = condition de retrait

15
01/01/2010

Entêtes de requêtes client HTTP
Max-Forwards = nombre max de proxy
Proxy-Authorization = identification
Range = zone du document à renvoyer

Didier Donsez, 1995-2010, HTTP

bytes=x-y (x=0 correspond au premier octet, y peut être
omis pour spécifier jusqu ’à la fin)

16
01/01/2010

Entêtes des réponses serveur HTTP
Accept-Range = accepte ou refus d ’une requête par
intervalle
Age = ancienneté du document en secondes
Proxy-Authenticate = système d ’authentification du proxy
Public = liste de méthodes non standards gérées par le
serveur
Retry-After = date ou nombre de secondes pour un ressai en
cas de code 503 (service unavailable)
Server = modèle de HTTPD
Didier Donsez, 1995-2010, HTTP

utilisé par Satan !!!!

Set-Cookie = créer ou modifie un cookie sur le client
Vary = l ’entité possède plusieurs sources
Warning = informations supplémentaire du code d ’état
14 Transformation applied : le proxy a changé de Content-Type ou
le Content-Encoding

WWW-Authenticate = système d ’authentification pour l ’URI

17
01/01/2010

Entêtes d ’entité HTTP
Allow = méthodes autorisées pour l ’URI
Content-Base = URI de base
pour la résolution des URL

Last-Modified = date de dernière modification du doc.
Utilisé par les caches

Content-Length = taille du document en octet
utilisé par le client pour gauger la progression des chargements

Content-Encoding = type encodage du document renvoyé
Didier Donsez, 1995-2010, HTTP

compress, x-gzip, x-zip

Content-Language : le langage du document retourné
fr, en ...

Content-Location : URI de l ’entité
quand l ’URI est à plusieurs endroits
18
01/01/2010

Entêtes d ’entité HTTP
Content-MD5 : résumé MD5 de l ’entité
Content-Range : position du corps partiel dans l ’entité
bytes x-y/taille

Content-Transfert-Encoding : transformation appliqué du corps
de l ’entité
7bit, binary, base64, quoted-printable

Content-Type = type MIME du document renvoyé

Didier Donsez, 1995-2010, HTTP

utilisé par le client pour sélectionner le visualisateur (plugin)
RFC2045

ETag : transformation appliqué du corps de l ’entité
7bit, binary, base64, quoted-printable

Expires : date de péremption de l ’entité
Refresh : 10
Refresh: 10; Location=/newloc.htm
19
01/01/2010

Internationalisation
Language Accept
fr, de, it, en, sq (albanais), ru, (russe), ja (japonais),
zh (chinois), el (grec), he (hébreu), ca (catalan) ...

Charset (table de caractère)

Didier Donsez, 1995-2010, HTTP

par défaut ISO-8859-1 (Latin-1)
ISO-8859-2 (hongrois, albanais, …)
ISO-8859- 4
ISO-8859-5, KOI8-R (russe, bulgare, polonais)
ISO-8859-7 (grec)
ISO-8859-8 (hébreu)
ISO-8859-9 (turc)
Shift_JIS, ISO-2022-JP, EUC-JP (japonais)
Big5 (chinois simplifié)
GB2312(chinois traditionnel - Taiwan)
20
01/01/2010

Récupération d ’un Document
Méthode GET
GET /doc.htm
UA

Didier Donsez, 1995-2010, HTTP

le Client envoie

HTTPD
port
80 machX

doc.htm

GET /doc.htm HTTP/1.0
méthode,chemin,version
Accept: www/source
documents acceptés
Accept: text/html
le Serveur répond
Accept: image/gif
User-Agent: Lynx/2.2 libwww/2.14 HTTP/1.0 200 OK ligne de status
Date: Wed, 02Feb97 23:04:12 GMT
From: alice@pays.merveilles.net
Server: NCSA/1.1
* une ligne blanche *
MIME-version: 1.0
Last-modified: Mon,15Nov96 23:33:16 GMT
Content-type: text/html
type du document retourné
Content-length: 2345
sa taille
* une ligne blanche *
<HTML><HEAD><TITLE> ...

21
01/01/2010

Soumission d ’un Formulaire
Méthode GET
GET /script?name1=value1&name2=value2
UA

Didier Donsez, 1995-2010, HTTP

le Client envoie

HTTPD
port
80 machX

script

GET /script?name1=value1&name2=value2 HTTP/1.0
Accept: www/source
documents acceptés
Accept: text/html
le Serveur répond
Accept: image/gif
User-Agent: Lynx/2.2 libwww/2.14 HTTP/1.0 200 OK ligne de status
Date: Wed, 02Feb97 23:04:12 GMT
From: alice@pays.merveilles.net
Server: NCSA/1.1
* une ligne blanche *
MIME-version: 1.0
Last-modified: Mon,15Nov96 23:33:16 GMT
Content-type: text/html
type du document retourné
Content-length: 2345
sa taille
* une ligne blanche *
<HTML><HEAD><TITLE> ...

22
01/01/2010

Soumission d ’un Formulaire
Méthode POST
POST /script

Didier Donsez, 1995-2010, HTTP

UA

le Client envoie
POST /script HTTP/1.0
Accept: www/source
Accept: text/html
Accept: image/gif
User-Agent: Lynx/2.2 libwww/2.14
From: alice@pays.merveilles.net
* une ligne blanche *
name1=value1&
name2=value2

HTTPD
port
80 machX

script

le Serveur répond
HTTP/1.0 200 OK
…
Content-length: 2345
* une ligne blanche *
<HTML><HEAD><TITLE> ...

23
01/01/2010

Codage des « paramètres »
Les valeurs passées (URL et contenu des entrées des formulaires) doivent
être sur 7 bits et sans caractères spéciaux

Format d ’encodage : x-www-form-urlencoded
Espace
Tous les caractères spéciaux et accentués
ascii

Didier Donsez, 1995-2010, HTTP

@
é

+
%code

%40
%e9

Les entrées des formulaires sont encodés dans une chaîne
composée de paires (nom de l ’entrée)=(valeur de l ’entrée) séparé
par de &
nom=Dupont+Jean&adresse=3+rue+de+la+Gait%e9%0a75014+Paris

il existe de nombreuses bibliothèques d ’encodage/décodage
dans le JDK :
static String java.net.URLDecoder.decode(String urlencoded, String
encodingscheme)
static String java.net.URLEncoder.encode(String str , String encodingscheme)

24
01/01/2010

Comportement du User Agent
face au type du document retourné
A partir du type MIME de Content-Type
Visualisation native
la fonction de visualisation est dans le noyau (core) du client
text/html, image/jpeg

Visualisation par plugin

Didier Donsez, 1995-2010, HTTP

la fonction est présente dans un DLL, SO, ou un JAR
elle est liée dynamiquement pour réaliser la visualisation
world/vrml, text/tex

Visualisation externe
la fonction n ’est pas présente dans le client
le client rapporte le document et le sauvegarde dans un fichier
temporaire
video/mpeg, application/postscript
25
01/01/2010

Requête Multi-parties (multipart)
Motivation

Didier Donsez, 1995-2010, HTTP

Requête multi-document [RFC1867]
formulaire HTML contenant des Upload de fichiers
<FORM ACTION="/servlet/UploadTest" ENCTYPE="multipart/formdata" METHOD=POST>
Your name? <INPUT TYPE=TEXT NAME=submitter> <BR>
Your first file to upload? <INPUT TYPE=FILE NAME=file1> <BR>
Your second file to upload? <INPUT TYPE=FILE NAME=file2> <BR
<INPUT TYPE=SUBMIT>
</FORM>

Remarque : Mail multi-documents
(fichiers attachés, mail enrichi d ’images, audio-mail …)
26
01/01/2010

Requête Multi-parties (multipart)
Codage de la requête
Une chaîne tirée aléatoirement sert de séparateur
Content-Type : multipart/form;boundary=End9989822
--End9989822

Didier Donsez, 1995-2010, HTTP

Content-Disposition; form-data; name="file1"; filename="test.htm"
Content-Type : text/html
<HTML><BODY> Ceci est un fichier de test !</BODY></HTML>
--End9989822
Content-Disposition; form-data; name="file2"; filename="test2.txt"
Content-Type : text/plain
Ceci est un deuxieme fichier de test !
--End9989822

Classes de manipulation (non standard)
voir [Hunter Ex4-18 p 107]
27
01/01/2010

Réponse Multi-parties
Codage
Content-Type : multipart/x-mixed-replace;
Frontière entre les parties
Déclaration : boundary=chaîne_aléatoire
Séparateur : --chaîne_aléatoire

Didier Donsez, 1995-2010, HTTP

Comportement
le navigateur affiche le sous-document suivant dès qu ’il
commence à le recevoir après avoir effacer la fenêtre.
Voir [Hunter ex6-12 p193]

28
01/01/2010

Réponse Multi-parties
Exemple
Content-Type : multipart/x-mixed-replace;boundary=End65577565679001838
ligne blanche
--End65577565679001838
Le serveur définit une chaîne
séparateur des documents

Content-Type : text/html
ligne blanche
<HTML><BODY><H1>Trois … </H1><BODY></HTML>
--End65577565679001838

Didier Donsez, 1995-2010, HTTP

Content-Type : text/html
ligne blanche
<HTML><BODY><H1>Deux … </H1><BODY></HTML>
--End65577565679001838
Content-Type : text/html
ligne blanche
<HTML><BODY><H1>Un … </H1><BODY></HTML>
--End65577565679001838
Content-Type : text/html
ligne blanche
<HTML><BODY><H1>Partez ! </H1><BODY></HTML>
--End65577565679001838

Le serveur attend 1 seconde
avant de renvoyer la suite :
le client affiche « Trois… »

Le serveur attend 1 seconde
avant de renvoyer la suite :
le client affiche « Deux… »

Le serveur attend 1 seconde
avant de renvoyer la suite :
le client affiche « Un… »
Le serveur clôt la connexion TCP/IP
avant de renvoyer la suite :
le client affiche finalement « Partez !»
29
01/01/2010

Suivi de Sessions avec HTTP
(Session Tracking)
Motivations :
La notion de session est importante dans une
application conversationnelle
commerce électronique
« j ’ajoute ce produit à mon panier (existant)»

Didier Donsez, 1995-2010, HTTP

Cependant HTTP est un protocole « stateless »
le serveur ne maintient pas d ’informations liées aux requêtes
précédentes d ’un même client.
HTTP est donc « sessionless »

Comment implanter la notion de session
sur plusieurs requêtes HTTP
documents, CGI, SSS, Servlet/JSP, ASP, PHP, …

30
01/01/2010

Suivi de Sessions avec HTTP
(Session Tracking)
Méthodes
Le serveur génère un identificateur de session et
associe un état (et une date limite de validité)
à une session
Le client renvoie l ’identificateur de session à chaque
requête HTTP vers le serveur

Didier Donsez, 1995-2010, HTTP

Echange et Stockage de l’identificateur de session
Input HIDDEN dans les formulaires
Réécriture des URLs (EXTRA_PATH)
Cookies (déactivable)
Identificateur de session SSL (Secure Socket Layer)
31
01/01/2010

Suivi de session avec HTTP
Une session s ’étend sur plusieurs requêtes
documents, CGI, SSS, Servlet, ASP
le serveur maintient un contexte de session
et y associe un identifiant de session

3 solutions de suivi
input HIDDEN
contient l ’identifiant de la session

la Ré-écriture d ’URL
l ’identifiant dans chaque URL (dans les documents)

Didier Donsez, 1995-2010, HTTP

les Cookies
information positionnée par le serveur sur le client
la durée de vie du cookie dépasse la session
puis envoyé par le client à chaque requête

Implantation
objet Session (ASP), classe HttpSession (JSP/Servlet)

32
01/01/2010

Suivi de Session
une entrée HIDDEN par formulaire (i)
Chaque réponse retournée par le serveur est un
formulaire qui contient un identifiant caché dans
une entrée HIDDEN
Exemple
• p a g e d e p ro p o s itio n

Didier Donsez, 1995-2010, HTTP

<FORM METHOD="POST" ACTION="/cgibin/command">
<INPUT TYPE="ckeckbox" NAME="art12387">
Chaussures
...
</FORM>

• ré p o n s e d e /c g i- b in /c o m m a n d
<FORM METHOD="POST" ACTION="/cgi-bin/envoi">
<INPUT TYPE="hidden" NAME="TransID"
VALUE="54109848932>
Nom:
<INPUT TYPE="text"
NAME="nom">
Adresse:
<INPUT
TYPE="text" NAME="adresse">
N° de Carte de Credit:
<INPUT
TYPE="text" NAME="numcarte">
...
<INPUT TYPE="hidden" NAME="Language"
VALUE="French>
</FORM>

33
01/01/2010

Suivi de Session
une entrée HIDDEN par formulaire (ii)
Inconvénients
dialogue uniquement par formulaire
car pas de persistance de l'identifiant côté client

Ambiguïté dans le cas des retours-arrière de l ’utilisateur
annulation d ’une série d ’actions

Didier Donsez, 1995-2010, HTTP

ou série d ’action supplémentaire

34
01/01/2010

Suivi de Session
la ré-écriture des URLs
L ’identifiant de session est encodé dans les URLs des
documents HTML retourné par le serveur.
http://localhost:8080/servlet/cart?PROD_ID=383

devient
http://localhost:8080/servlet/cart;jsessionid=To1128mC33718557521577075At?PROD_ID=383

Codage différent d’un serveur à l’autre.

Didier Donsez, 1995-2010, HTTP

field_sessionID = "JServSessionIdroot";
field_sessionID = ";jsessionid=";
field_sessionID = "JIGSAW-SESSION-ID";
field_sessionID = ";$sessionid$";

//Apache/Jserv
//Jakarta-Tomcat
//Jigsaw web servers
// WebSphere

Limites
URL générée par un script (=>programmation)
ou parsing des documents HTML retournés
mais disfonctionnement en présence de scripts JavaScript ou VBScript
générant eux aussi des URL !
35
01/01/2010

Suivi de Session
les Cookies [Netscape puis RFC2109]
chaîne décrivant l'état d'une session
NAME=VALUE;
expires=DATE;
path=PATH_HEAD;
/ << /foo << /foobar ou /foo/bar.html
domain=DOMAIN_TAIL; fr << mycomp.fr << sales.mycomp.fr

stocké sur le client
Limite

Didier Donsez, 1995-2010, HTTP

300 cookies simultanées par client, 20 cookies par serveur ou
domaine, 4Ko par cookie (limite la taille des VALUEs)

communiqué dans les entêtes de requêtes
(Cookie:) et dans les entêtes des réponses HTTP (SetCookie:)
accessible par les scripts JavaScript dans une page HTML
36
01/01/2010

Positionnement des Cookies (i)
GET /

Web
Browser

Set-Cookie: VisitorID=12345; path=/;
GET /book
Cookie: VisitorID=12345;
Set-Cookie: SID_book=88; path=/book;

Didier Donsez, 1995-2010, HTTP

GET /book/order
Cookie: VisitorID=12345;
Web browser’ cookies table Cookie:SID_book=88;
VisitorID=12345; path=/;

/
/book
/music
Didier
Donsez

Web
Server

SID_book=88; path=/book;

GET /music
SID_music=999; path=/music; Cookie: VisitorID=12345;
Set-Cookie: SID_music=999; path=/music;
GET /music/buy
Cookie: VisitorID=12345;
Cookie: SID_music=999;

37
01/01/2010

Positionnement des Cookies (ii)

Un autre jour !

Same
Web
Browser

GET /
Cookie: VisitorID=12345;

GET /book
Cookie: VisitorID=12345;

Didier Donsez, 1995-2010, HTTP

Set-Cookie: SID_book=101; path=/book;
GET /book/logout
Web browser’ cookies table Cookie: VisitorID=12345;
Cookie:SID_book=101;
VisitorID=12345; path=/;
Set-Cookie: SID_book=0; path=/book; 
SID_book=101; path=/book;
expires=0

GET /
Cookie:

VisitorID=12345;

/
/book
/music
Didier
Donsez

Web
Server

38
01/01/2010

CC/PP (Composite Capabilities/Preference Profiles)
Motivation
Capacité du UA mobile et préférence usager envoyé au serveur
en vue d’adapter la réponse

Descriptions RDF
Terminal
Display size
CPU
Operating system
Supported HTML Version
Didier Donsez, 1995-2010, HTTP

Usager

Compatible WAP UAPROF
Remarque:
Devenu un nouveau WG « Device Independence »
44
01/01/2010

HTTPS (S comme Secure)
Motivation
Sécuriser (authentification, confidentialité) l’accès à un service Web

SSL/TLS
Phase 1 : Authentification du serveur et/ou du client par PKI
Phase 2: Chiffrage avec une clé (secrète) symétrique de session
Phase 2bis : Reprise après déconnexion

HTTP over SSL (TLS)
URL : https://host/document (Port TCP par défaut : 443)
Didier Donsez, 1995-2010, HTTP

HTTPS dans le JDK
JSSE (javax.net.ssl.*) inclus dans J2SE 1.4
classe javax.net.HttpsURLConnection
Voir cours JCE (http://wwwadele.imag.fr/users/Didier.Donsez/cours/jce.pdf)

Serveurs
Apache/SSL, iPlanet, MS IIS, OracleAS, IBM WebSphere …
Carte hardware accélératrice (nFast de nCipher)

48
01/01/2010

HTTP-R (R comme « Reliable »
Fiable)
Under Construction

En
Proposé par IBM au W3C, mais toujours en coursConstruction
;-(
Rappel
HTTP est une couche de transport pour les messages SOAP
dans la mise en œuvre les Web Services (B2B, EAI)

Motivation
Fiabiliser l’échange de messages entre le client et le service Web
Échanger une et une seul fois
même en cas d’interruption (déconnection, …)

Didier Donsez, 1995-2010, HTTP

Batch de plusieurs messages (requêtes et réponses) par
commande

Principe d’HTTPR
Journaliser les messages (requêtes et réponses) côté client et côté
serveur
Notion de transaction
Valider/Acquiter les échanges avec un protocole de validation
Ajout de nouvelles commandes
49
01/01/2010

Nouvelles « commandes » de HTTPR
Under Construction

Ces commandes sont portées par la commande HTTP POST En Construction

PUSH
Le client envoie un ou plusieurs messages qui seront journalisées par le
serveur
La séquence de messages est associée à un identifiant de transaction
Peut contenir des acquittements à des commandes précédentes

PULL
Demande à recevoir des messages en attente coté serveur
Peut contenir des acquittements à des commandes précédentes

EXCHANGE
Didier Donsez, 1995-2010, HTTP

Combine PUSH et PULL

RESOLVE
Permet de déterminer les messages recus et journalisés par le serveur

REPORT
Permet de rapporter au serveur les messages recus et journalisés par le
client

GET RESPONDER INFO
Information pour le serveur sur le niveau de protocole supporté par le client
50
01/01/2010

HTTPU & HTTPMU
HTTPU (HTTP Unicast over UDP)
HTTPMU (HTTP Multicast over UDP)

Under Construction
En Construction

Didier Donsez, 1995-2010, HTTP

Utilisé par UPnP
http ://www.upnp.org/about/default.asp
pour le protocole de découverte de service (SSDS
(Simple Service Discovery Protocol))

52
01/01/2010

XML-RPC vs SOAP vs REST
Motivations
Program-to-Program
B2B, AJAX, …

XML-RPC
HTTP POST
Simple encoding schema
Didier Donsez, 1995-2010, HTTP

SOAP
operation-centric
WSDL

REST
more URL-centric
53
01/01/2010

REST (Representational State
Transfer)
“Amazon has both SOAP and REST interfaces to their web
services, and 85% of their usage is of the REST interface.”

Motivation

Didier Donsez, 1995-2010, HTTP

L’encodage d’une requete SOAP est complexe pour le néophyte
Utilisation du passage de paramètre de HTTP GET

Roy Thomas Fielding. Architectural styles and the design of
network-based software architectures. PhD thesis, University of
California, Irvine, 2000.
http://www.ics.uci.edu/~fielding/pubs/dissertation/top.htm
54
Les clients (UA) et les serveurs
HTTP

Didier DONSEZ
Université Joseph Fourier (Grenoble 1)
PolyTech’Grenoble – LIG/ADELE
Didier.Donsez@imag.fr Didier.Donsez@ieee.org
01/01/2010

Les Client (User-Agents) HTTP
Butineur ou Arpenteur ou Brouteur Web (browser Web)
Récupère un document puis « visualise » ce document

Didier Donsez, 1995-2010, HTTP

Sur station
le tout premier : NCSA Mosaic
Netscape Communicator/Mozilla/Firefox
MS Internet Explorer
Opera
Konqueror
Javasoft HotJava
…
Lynx (pour VT, Minitel 24x80)
AvantGo, MS Pocket Explorer, … (pour PDA)

56
01/01/2010

Autres Client (User-Agents) HTTP
HTTPClient http://hc.apache.org/
components for client-side authentication, HTTP state management, connection management,
and an HTTP/1.1. compliant HTTP agent implementation based on those components

Curl http://curl.haxx.se/docs/manpage.html

Didier Donsez, 1995-2010, HTTP

command line tool for transferring files with URL syntax, supporting FTP, FTPS, HTTP, HTTPS,
SCP, SFTP, TFTP, TELNET, DICT, LDAP, LDAPS and FILE. curl supports SSL certificates,
HTTP POST, HTTP PUT, FTP uploading, HTTP form based upload, proxies, cookies,
user+password authentication (Basic, Digest, NTLM, Negotiate, kerberos...), file transfer resume,
proxy tunneling and a busload of other useful tricks.

57
01/01/2010

Palmarès d ’utilisation des butineurs
MS IE est en tête
12/2002

Didier Donsez, 1995-2010, HTTP

Microsoft IE 6.0
Microsoft IE 5.5
Microsoft IE 5.0
Netscape Navigator 4.0
Mozilla 1
Microsoft IE 4.0
Opera 6.0
The winner is ...
Microsoft IE
Netscape Navigator
Mozilla

07/2003

57.6%
18.3%
16.9%
1.1%
1.1%
0.9%
0.8%

66.3%
14.5%
12.7%
0.6%
1.6%
0.8%
0.6%

95.0%
3.0%
1.1%

95.4%
2.5%
1.6%
58
01/01/2010

Les User-Agents HTTP
Mais aussi
sur Console de Jeux, PDA, iTV, Téléphone Cellulaire
WinCE Pocket Explorer, AvantGo ...

Navigation Online / Offline

Didier Donsez, 1995-2010, HTTP

Ladtop, PDA, …
Récupération en push dans un cache
Puis consultation des documents dans le cache

59
01/01/2010

Les Serveurs du Marché
Offre logiciel très large
NSCA HTTPD, l’ancêtre
Apache & Jakarta/Tomcat (19 millions de serveurs (09/2001))
iPlanet et Netscape Entreprise Server
Microsoft Internet Information Server (8.9 millions de serveurs

(09/2001))
W3C Jigsaw
Sun JavaServer
Oracle Web Server, abandonné par Oracle au profit d’Apache
IBM Web Sphere, intègre Apache
Resin, Jetty, Zeus…
Didier Donsez, 1995-2010, HTTP

Offre matériel
Server Appliances : Qube, …
Composants pour des serveurs embarqués

Fonctionnalités supplémentaires
gestion des sessions, des transactions, …
accès aux serveurs d ’applications, ...

A regarder régulièrement
http://news.netcraft.com/archives/web_server_survey.html

60
01/01/2010

Les Serveurs du Marché
Nombre de site

Didier Donsez, 1995-2010, HTTP

http://news.netcraft.com/archives/web_server_survey.html

61
01/01/2010

Les Serveurs du Marché
Market share

Didier Donsez, 1995-2010, HTTP

http://news.netcraft.com/archives/web_server_survey.html

62
01/01/2010

Rôle d'un serveur HTTP
Transformation de l'URL en fichier ou en script
Vérification d'identité
Le client est-il qui il prétend être ?

Vérification d'accès
Le client est-il autorisé à effectuer cette requête ?
ACL, …

Constitution de l ’entête de la réponse
Type MIME des données
Didier Donsez, 1995-2010, HTTP

mime.types fichier de correspondance extension vers type MIME

Taille des données, Langage, ...

Envoi de la réponse au client
éventuellement transformé à la volée

Mise à jour des journaux d ’audit (log)
access_log, error_log, ...
63
01/01/2010

L ’authentification dans HTTP
Indiqué dans les ACL
Mode d ’authentification
BASIC (RFC 2617)
nom d ’utilisateur et mot de passe échangé en clair (base64) !
base des mots de passe dans un fichier htpasswd
utilitaires de gestion du fichier

DIGEST (RFC 2617)

Didier Donsez, 1995-2010, HTTP

sécurisation de BASIC
hachage sécurisé MD5 du (nom,password,URI, méthode,nombre
aléatoire fourni par le serveur)

SSL/TLS
Secure Socket Layer (TLS : Transport Layer Security)
authentification avec CA du serveur (2.0) et du client (3.0)
confidentialité avec DES
puis dialogue HTTP sur la connexion SSL
Remarque : utilisation des cartes PKI pour l’identification du client

64
01/01/2010

L ’authentification applicative
Motivations
interface de login
authentification plus forte (SSL)
Base d’identité
Fichier htpasswd, BD, Annuaire LDAP, … (voir mod_auth_xxx de
Apache)

L’application gère l ’authentification de l ’usager

Didier Donsez, 1995-2010, HTTP

formulaire d ’accueil HTML (nom, password)
attention le mot de passe circule en « clair »
Utilisez une fonction JavaScript de hachage (MD5,SHA1) du mot
de passe avec un nombre aléatoire pour éviter le « replay »

gestion des tables d ’usager
une session est ensuite ouverte associé à un usager authentifié (ou
non : par exemple rejet à bout de 3 tentatives)

Remarque
TomCat peut de préciser les documents de login et d’errreur pour
une arborescence de documents/servlets/JSP

65
01/01/2010

Contrôle d ’Accès dans HTTP
ACL (Access Control List)
spécifie les autorisations (ALLOW) ou les interdictions
(DENY) d ’accès à une arborescence virtuelle du
serveur
en fonction

Didier Donsez, 1995-2010, HTTP

de l ’authentification
de la localisation du client
sous domaine DNS
réseau ou adresse IP

ACF (Access Control File)
fichier regroupant les ACL
global : access.conf dans Apache
par arborescence : .htaccess

combinaison des ALLOW et des DENY
66
01/01/2010

Audit des Requêtes
Journaux des requêtes
les accès (access.log, refferee.log), et les erreurs
(error.log), … sont journalisés

Exploitation des Journaux
erreur dans les liens, …
clientèle, analyse d ’activité, …

Didier Donsez, 1995-2010, HTTP

Reporting (Présentation Synthétique)
Pour Apache
AccessWatch, Wusage,Analog, wwwstat

IIS, NS
intégré et visualisé par un script

Généraux
Net Analysis (Net Genesis), Enterprise Suite (Web Trends)
67
01/01/2010

Apache
(www.apache.org)
A patch of NCSA HTTPD
serveur le plus répandu (62% des serveurs au 04/2001, 18 Millions
de serveur)
gratuit, issu du serveur NCSA HTTPD
très nombreuses plates-formes Unix et Windows NT
extensible par des modules tiers

Nombreux Modules Tiers

Didier Donsez, 1995-2010, HTTP

possibilité d’étendre Apache avec des modules externes
(http://www.zyzzzyva.com/server/module_registry)
mod_auth_cookies_file, mod_auth_cookies_msql, mod_cgi_sugid,
mod_perl, mod_perl_fast, mod_auth_kerb, mod_auth_dbi,
mod_rewrite, mod_jserv (servlet), mod_java (CGI écrit en Java), php3

nombreux sous-projets autour de Java (Jakarta) et XML (Xerces,
Xalan, XSP, Cocoon, …)
68
01/01/2010

Jakarta Tomcat
(jakarta.apache.org)
Moteur (engine) de Servlet/JSP
Catalina : Container JavaEE de Servlet
Jasper : Container JavaEE de JSP

Connecteurs
Admin (8007)
Démarrer/relancer/arrêter Tomcat

HTTP 1.1
peut servir directement des clients HTTP

Didier Donsez, 1995-2010, HTTP

HTTPS
peut servir directement des clients HTTP sur SSL/TLS
Il est préférable d’utiliser Apache/SSL + AJP12, AJP13, WARP

AJP12, AJP13, WARP
Avec des serveurs HTTP supportant WARP

Fonctionnement possible en « embedded »
cad dans une machine virtuelle avec d’autres services (containers
EJB, …)
70
01/01/2010

Apache/JServ et Jakarta Tomcat
(java.apache.org)
mod_Jserv / mod_jk : module d’extension Apache
Démarre une JVM et invoque des servlets

TomCat : serveur écrit en Java
A utiliser comme Servlet et JSP engine

Configuration possible
Apache
Server
mod_xxx

Didier Donsez, 1995-2010, HTTP

(.dll, .so)

Client
HTML
Client
HTML
Client
HTML

HTML
HTTP/HTTPS

HTML
mod_jserv/jk AJP
(.dll, .so) (port 8007)

HTML
HTTP/HTTPS
HTML
HTTP/HTTPS

A éviter
en production
(perf, sécurité)

Pages
Statiques
Jakarta TomCat
Server
servlet/jsp
servlet/jsp
FileServlet

Pages
Statiques
71
01/01/2010

JavaServer
Serveur HTTPD de SUN
anciennement « Jeeves », écrit en Java
Abandonné au profit de Tomcat (jakarta.apache.com)
qui est devenu l’implémentation de références pour les Servlets,
JSP, JSTL

Servlets

Didier Donsez, 1995-2010, HTTP

Scripts serveur écrit en Java
Servlets de Base : FileServlet, CGIServlet, …

Remarque
le bytecode d ’une servlet peut être téléchargé et
executé par la JVM du Serveur (dans un espace protégé
ou non)
JigSaw du W3C fonctionne suivant le même principe
72
01/01/2010

MS Internet Information Server
Plate-forme Systèmes Serveur de Windows
8.9 millions de serveurs (09/2001)

Scripts
ASP, ASP .NET
Interface native ISAPI (C, C++, …)

Didier Donsez, 1995-2010, HTTP

Remarque
PWS : Personal Web Server (pour les systèmes
WorkStation)
Maintenant intégré à MS .NET (Web Services, …)
Cassini (ASP .NET Web Server pour le développement)

73
01/01/2010

Autour d ’HTTP
Proxy
seul point de passage entre le réseau d ’entreprise et l extérieur
sécurité, firewall

accès à des protocoles non implémentés par les clients Web : WAIS, …

Cache
soulager les accès externes (moins de bande passante)

Miroir
réplication d ’une base documentaire
améliorer le temps de réponse, soulager le réseau

Robot

Didier Donsez, 1995-2010, HTTP

récupération online/offline d ’une arborescence de documents
constitution d ’un miroir local

Mise à jour de sites
copie publique / copies de travail

Portail
Point d’accès centralisant à un ensemble de sources Web

Embedded Web Server
Serveur HTTP pour informatique enfouie et embarquée
81
01/01/2010

Proxy
Fonctions
seul point de passage entre le réseau d ’entreprise et
l ’extérieur
firewall, contrôler le profil d'utilisation, portail vers des
ressources externes contrôlées (banques de données, …)

accès à des protocoles non implémentés par les clients
Web
Didier Donsez, 1995-2010, HTTP

WAIS, LDAP…

Passerelle réseau de niveau applicatif
Navigateur Web
HTTP + HTML

Proxy
HTTP+HTML / WAIS

Serveur WAIS
Z35.50

Couches OSI
1-6

Couches OSI
1-6

Couches OSI
1-6
82
01/01/2010

Fonctionnement du Proxy/Cache
GET /fichier
HTTPD

Client

port
80 machX

GET /ficX

Didier Donsez, 1995-2010, HTTP

GET http://machX/ficX
Client

fichier

Proxy

GET http://machY/ficY

Entreprise

ficX

machX

port
8080
cache
machP

HTTPD

HTTPD
GET /ficY

ficY

machY
Internet

83
01/01/2010

Cache Web
But d ’un cache Réseau
Usager
Améliorer les performances du browser en utilisant les documents
présents dans le cache local

ISP
Soulager le réseau fédérateur en cachant les documents demandés
par les usagers du sous-réseau

Provider Web
Soulager les serveurs applicatifs

Didier Donsez, 1995-2010, HTTP

Documents
Textes (HTML, XML, ...) et Images fixes
Flux Audio et Video
têtes de réseau cable pour la Buffered-VOD

Serveurs
Il fonctionne en mode Proxy
Squid, Harvest, Apache, MicroSoft, Sun, iPlanet, OracleAS WebCache, WebSphere
...

84
01/01/2010

Cache Web ii
Politique de remplacement de cache Web
Least Recently Used (LRU) très populaire
conserve la date du dernier accès

Least Frequently Used (LFU)
comptage du nombre de références
éviction des documents les moins référencés

Didier Donsez, 1995-2010, HTTP

LFU-Aging
LFU + prise en compte de la durée de la présence dans le
cache

Greedy Dual-Size (GDS)
prise en compte la taille

GDS-Frequency (GDSF)
GDS + prise en compte du nombre de référence
85
01/01/2010

Cache Web iii
Cache de Caches
Hiérarchie multi-niveaux de caches
exemple : RENATER
cache Client -> cache Sous Réseau -> cache Backbone -> ...

équilibrage dynamique
entre plusieurs caches de même niveau

ICP : Inter Cache Protocol
Didier Donsez, 1995-2010, HTTP

mise à jour, invalidation, redirections de requête

86
01/01/2010

Gestion du Cache
Le document est il
dans le cache ?
Non
Non

Oui
Le document est il périmé ?
date d ’expiration dépassée

Didier Donsez, 1995-2010, HTTP

Oui
Non : le cache arrête la
connexion avec le serveur
et retourne au client
le document caché

le cache démarre la récupération
Le document a t’il été modifié ?
date de modification identique

le cache se connexe au
serveur pour récupérer
l ’entête (méthode HEAD)

Oui
Le serveur continue la
récupération même si le
client interrompt la
connexion

Le document est récupéré,
mis dans le cache,
retourné au client
87
01/01/2010

Content Delivery Network (CDN)
Web cache aux points de présence du(des) FAI
entre le fournisseur et ses clients
Documents cachés
Statique, Stream, Fragments de compositions dynamiques (ESI)

Avantages
Latence réduite, décharge du serveur fournisseur (allocation de
serveurs à la demande, …), décharge du réseau central FAIs

Didier Donsez, 1995-2010, HTTP

Inconvénients
Usage de DNS dynamique dissociée pour cachable et non
cachable
Réécriture dynamique d’URL

Acteurs
Akamaï (+Digital Island) ~80% du marché
plus de 20000 (surogate) serveurs low-cost sur 63 pays

Adero, Mirror Image, Inktomi, …
88
01/01/2010

Content Delivery Network (CDN)
le Edge Computing

navigateurs web

pull

Internet
serveurs
applicatifs

Didier Donsez, 1995-2010, HTTP

requêtes par
millions

navigateurs web

centaines de
serveurs
frontières
pull

requêtes par
millions

Dynamic Caching
and Content
Assembly

Internet

fragments HTML
à cacher

requêtes par
millions

serveurs
applicatif
requêtes
par milliers

serveurs
bases de
données
requêtes par
millions

serveur
bases de
données
requêtes
par milliers
89
01/01/2010

Miroir
But
Créer une copie miroir d ’un site (d ’une partie de site)
accélère l ’accès au document
diminue la contention d ’accès au site
diminue le trafic global sur Internet

Mise à jour du miroir

Didier Donsez, 1995-2010, HTTP

déclenchement automatique, manuel, push
incrémentale / non

91
01/01/2010

iCAP (i)
Internet Content Adaptation Protocol
Motivations
permettre à un proxy (HTTP, FTP, NNTP, SMTP)
d’intercepter les messages et de les faire traiter/modifier
« à la volée » par d’autres services

Didier Donsez, 1995-2010, HTTP

Exemple d’utilisation :
Détection de virus, Insertion de bannière publicitaire,
Reroutage, Détection de langage, Traduction
multilingue, Conversion de format (image, …),Contrôle
parental …

92
01/01/2010

iCAP (ii)
Internet Content Adaptation Protocol
Architecture
Client
HTTP

Didier Donsez, 1995-2010, HTTP

Protocole

Proxy HTTP
(Client iCAP)

Serveur iCAP
Antivirus

Serveur
HTTP

Serveur iCAP
Traducteur

RFC IETF
Couche Transport : HTTP
Méthodes : RESPMOD, REQMOD, OPTIONS
Encapsulation du message (HTTP, …)

URL : icap://host:port/service (port par défaut : 1344)
Implémentation : iPlanet, …
93
01/01/2010

iCAP(iii)
Service

Architecture
Request
Satisfaction

Response
Modification

Result
Modification

Content
Filtering

Yes

Yes

Yes

Yes

Gateway
Translation

Yes

Language
Translation
Didier Donsez, 1995-2010, HTTP

Request
Modification

Yes

Virus
Scanning
Ad Insertion
Data
Compression

Yes

Yes

Yes

Yes
Yes

Yes

Yes

Yes

Yes

Yes
94
01/01/2010

Robot
(Aspirateur de Site, Glaneur, ...)
Récupération d ’une arborescence de documents
à partir d ’une URL « racine »
Règles de récupération
par rapport aux extensions (que les textes)
profondeur du suivi de URL et limite de la récupération

Déclenchement programmé
heures creuses (débit et $)

Produits
nombreux freewares/sharewares
Didier Donsez, 1995-2010, HTTP

webcopy, wget, w3mir, Jobo ...

Fonction miroir intégrée dans les logiciels auteurs
MS FrontPage, Goto MemoWeb, ...

Remarque
permet de créer facilement un miroir
utile à la navigation offline
95
01/01/2010

Robot
Directive pour les robots
Faciliter le travail des robots des moteurs d’indexation

META HTML
<META NAME='revisit-after' CONTENT='15 days'>
<META NAME='robots' CONTENT='index,follow'>
<META NAME="keywords" CONTENT="Cours HTTP, Robot, WebDAV ">

Fichier /robots.txt (http://www.robotstxt.org/wc/norobots.html)

Didier Donsez, 1995-2010, HTTP

Interdit aux robots certains répertoires ou documents
Exemple
# interdit cyberworld/map/ a tout robot
User-agent: *
Disallow: /cyberworld/map/
# sauf à Cybermapper qui peut tout visiter
User-agent: cybermapper
Disallow:
96
01/01/2010

Mise à jour des sites
Actuellement, chaque auteur travaille sur une copie locale et
remplace la copie publiée sur le Web par celle-çi régulièrement

Remplacement des pages
par FTP
problème de gestion des versions multiples
lors d ’un travail de groupe

par un script HTTP serveur propriétaire

Didier Donsez, 1995-2010, HTTP

et information propriétaire associée
utilisé par MS FrontPage, NetObjects Team Fusion, Macromedia
DreamWeaver, …

mais pas d ’interopérabilité

WebDAV [RFC 2518]
Web Distributed Authoring and Versioning Protocol
le dernier effort de standardisation
97
01/01/2010

WebDAV (1/3)
Web Distributed Authoring and Versioning Protocol
Extension de HTTP pour la mise à jour de site (RFC
2518)
www.webdav.org, www.ics.uci.edu/pub/ietf/webdav

Notions
Propertie (propriété)

Didier Donsez, 1995-2010, HTTP

décrit un document (auteur, taille, date de dernière modification,
...) au format XML/RDF

Collection
Locking (verrouillage)
verrou partagé (shared) / verrou exclusif (exclusive)

Namespace (espace de nommage)
groupement logique de ressource pour la gestion (verrouillage,
contrôle d ’accès, ...)
98
01/01/2010

WebDAV (2/3)
Web Distributed Authoring and Versioning Protocol

Ajout de nouvelles commandes HTTP
PROPFIND
retourne les propriétés

PROPPATCH
modifie les propriétés

MKCOL
crée une nouvelle collection
Didier Donsez, 1995-2010, HTTP

COPY & MOVE
copie ou déplace une ressource au sein d ’un espace de
nommage

LOCK & UNLOCK
verrouille et déverouille un ressource
99
01/01/2010

WebDAV (3/3)
Web Distributed Authoring and Versioning Protocol
des Serveurs WebDAV
MS IIS5
CyberTeams ’ Web Site Director
mod_dav pour Apache (www.webdav.org/mod_dav)
Support dans Tomcat
org.apache.catalina.servlets.WebdavServlet

Didier Donsez, 1995-2010, HTTP

des Clients WebDAV
MS Office 2000 et Explorer 5
Adobe GoLive)
Cadaver 0.15
DAV Explorer 0.60 and 0.70
Jakarta Slide 1.0 WebDAV client library
SkunkDAV 1.0

A voir
http://www.webdav.org

100
01/01/2010

WebDAV/DeltaV (RFC 3253)
Extension de WebDAV pour le support des
révisions
Auto-versionning

Didier Donsez, 1995-2010, HTTP

Possibilité de révision avec des clients WebDAV non
DeltaV

Utilisé par SubVersion mod_dav_svn (http/https)

101
01/01/2010

Portail (i)
Objectif
Point d’accès centralisant un ensemble de sources d’information Web
Intra-entreprise (Enterprise Information Portal ou Web Based Groupware)
Contenu : Favorite links, Agenda, Mail, Incident, Challenge Force de Vente
…
Grand public
Contenu : Info Bourse, Enchère, Météo, Programme TV et Ciné, News
Headline, Courrier (HTML), SMS …
B2B pour des agrégateurs de Web Services

Fonctionnalités
Usagers Anomymes/Authentifiés
Didier Donsez, 1995-2010, HTTP

Sécurisation (SSL, X509, cookie …)

Personnalisé
en fonction de l’usager, de son role, de son emplacement géographique, …

Personnalisable(Self-Service)
Composition dynamique (utilisation d’assistants, …)

Multi-Accès (PC, Téléphone Cellulaire, PDA, …)

Outils
JSR 168, Oracle Portal, NetPortal, WebPortal, iPlanet Portal, Apache
Portals, …

102
01/01/2010

Portail (ii)
Présentation (GUI)
1 page d’accueil composite -> N onglets -> M zones (div, layer, frame, card, …)
iconifiable, agrandissement/réduction, ajout/retrait, …

Développement de Portlet
Notion de PortLet : représente une source de données à placer dans la
page

Portal Server
Identification

LDAP, …
Annuaire, …

HTML/CSS

Personnalisation

XML/XSL

PortLet

Didier Donsez, 1995-2010, HTTP

WML

Client

VoiceML
HTTP
WAP

Portlet
Container

PortLet
PortLet
PortLet

Nouveau métier : provider de PortLet

HTML
HTTP
XML
HTTP
XML
HTTP
SOAP
HTTP

Internal
Web Provider
Internal
Web Provider
External (Meteo)
Web Provider
External (Bourse)
Web Provider
103
01/01/2010

Portail (iii)
Exemple de GUI HTML (My Yahoo)
Identification
Portlet
Portfolio

Portlet Mail

Didier Donsez, 1995-2010, HTTP

Portlet News

Portlet
Weather
104
01/01/2010

Portails Apache http://portals.apache.org/
JetSpeed 1 et 2
Servlet de portail Web et WAP
Description
PSML (Portal Structure Markup Language) par utilisateur
Description des portlets et de leur contenu, de leur mise en page

Pluto

Didier Donsez, 1995-2010, HTTP

Reference Implementation of the Java Portlet Specification (JSR
168)
Pluto is a portlet container.

WSRP4J
Reference Implementation of the Oasis (Web Services for Remote
Portlets) Specification. WSRP standard simplifies integration of
remote applications/content into portals so that portal administrators
can pick from a rich choice of services and integrate it in their portal
without programming effort.
105
01/01/2010

Cartographie du Web
Grouper les sites en « régions »
en fonction de leur relation sémantique, des références
d ’URL

Représentation de la carte

Didier Donsez, 1995-2010, HTTP

hyperbolique, cible 2D, …

Outils et sites
www.semio.com, www.acetic.fr, www.umap.com, ...

106
01/01/2010

Mesures et Rapports
d ’audience (MédiaMétrie)
Pourquoi faire : suivi et analyse de l ’activité du site
webmaster : dimensionner le système (période de charge)
commercial : pister le client dans sa navigation
investisseur : le rassurer avant l ’introduction en Bourse ;-)
publicitaire : fixer le prix des bandeaux publicitaires

2 fonctions

Didier Donsez, 1995-2010, HTTP

Récupération des clics
à partir des journaux du serveur HTTP (access.log)
inconvenients : les journaux grossissent très vite
scripts JavaScript/applet embarqués dans les pages
Images masquées

Analyse
Datawarehouse, DataMining
Rapport, OLAP, Segmentation online (Profilage online)
107
01/01/2010

Mesures et Rapports
d ’audience (MédiaMétrie)
Acteurs
Insight (Accrue), WebHound (SAS Institute)
http://awstats.sourceforge.net/

Didier Donsez, 1995-2010, HTTP

A lire
DEVANSHU DHYANI, WEE KEONG NG, SOURAV S.
BHOWMICK, « A Survey of Web Metrics », ACM
Computing Surveys, Vol. 34, No. 4, December 2002.

108
01/01/2010

Mesures et Rapports
d ’audience (MédiaMétrie)
Externalisation des rapports d’audiance
Pourquoi faire : rapport de l’activité du site
investisseur : le rassurer avant l ’introduction en Bourse ;-)
publicitaire : fixer le prix des bandeaux publicitaires

Didier Donsez, 1995-2010, HTTP

Méthodes
société tierce « indépendante » proposant des rapports
« normalisés » (Exemple : www.estat.com, ...).
chaque page à tracer contient une image transparente de 1x1 pixel
qui est chargée depuis la société tierce. La société tierce
comptabilise les chargements.
<IMG SRC="http://www.tierce.com?idcust=190874+doc=/product/index.htm">

109
01/01/2010

Rapports d ’audience
Exemple

Didier Donsez, 1995-2010, HTTP

Rapport d ’audience

110
01/01/2010

Rapports d ’audience
Exemple

Didier Donsez, 1995-2010, HTTP

Rapport d ’audience Temps réel de
www.geoloc.com

111
01/01/2010

Service pour le e-Commerce
Géo-localisation IP
Pays d’origine d’une adresse/domaine IP
Ex: http://www.maxmind.com/

Validation des cartes de crédit/bancaires
Pays d’origine fortement sujet à la fraude

Didier Donsez, 1995-2010, HTTP

Ukraine, Indonesia, Yugoslavia, Lithuania, Egypt, Romania,
Bulgaria Turkey, Russia, Pakistan, Malaysia, Israel, …

Services externes via des Web-Services

112
01/01/2010

La Personnalisation
Motivations
Les usagers d ’un site ont des goûts et des besoins différents
La personnalisation tente d ’offrir à l ’usager une interface
correspondant le plus possible à ses goûts et ses besoins

Solutions
Analyse (E-Analytics)

Didier Donsez, 1995-2010, HTTP

Analyse des navigations précédentes de l ’usager
Net Perceptions, Accrue Software, NetGenesis Corp

Personnalisation sur règles (Rules-based
Personalization)
Création des pages personnalisées à la volée en fonction de
régles
BroadVision, Vignette Corp.

Filtrage collaboratif (Collaborative Filtering)
similarité entre utilisateurs : comportement de groupes
Net Perceptions, Macromedia, Be Free

113
01/01/2010

Qualité
Motivation
Vérification de la Conformité (Correctness) aux
spécifications (donné par le client)
Non régression

Outils

Didier Donsez, 1995-2010, HTTP

Test unitaire et rapport : JUnit+Cactus

114
01/01/2010

Test de performance / charge
Motivation
Vérification du niveau de charge supporté avant la mise en
production

Benchmark
TPC-W (Bookstore online) http://www.tpc.org voir Cours Benchmarks

Didier Donsez, 1995-2010, HTTP

BD

WebMark : orienté requête HTTP/GET sur des documents statiques
SPECWeb : http://www.spec.org/osg/web99/
Rubis (eBay auction) http://rubis.objectweb.org
Rubos (PHP News SlashDot)
CSIRO (Stock online)
Mauro Andreolini, Valeria Cardellini, Michele Colajanni: Benchmarking Models
and Tools for Distributed Web-Server Systems. Performance 2002: 208-235

Analyse et diagnostique de la charge
Détecter quel composant (HTTPD, EJB, MT, SGBD, Mailhost, MQ
115
…) en créant l’embouteuillage (bottleneck)
01/01/2010

Test de performance / charge (ii)
Injecteur de charge
1à N clients en parallèle qui émulent M WebSurfers sur
le site
Script définissant la navigation (automate, temporisation, …)
Monitoring

Monitoring

Didier Donsez, 1995-2010, HTTP

Tested system

Simulate clients
connections

Cluster of
clients

Frontend

Application
Server

Backend
116
01/01/2010

Test de performance / charge (iii)
Outils
Apache Benchmark Tool (ab), Siege, Apache JMeter,
ObjectWeb CLIF, IBM/Rational SiteLoad, LoadRunner,
TestMaker, Grinder (http://grinder.sourceforge.net/), …

Remarque

Didier Donsez, 1995-2010, HTTP

Mêmes outils pour les attaques DoS (Deny-Of-Service)
et Distributed DoS

117
01/01/2010

Test de performance / charge (iv)
Exemple: Apache JMeter

Didier Donsez, 1995-2010, HTTP

Screenshot to add

118
01/01/2010

Balancing)
Disponibilité (Avaibility)
Motivations
Performance
Améliorer/garantir les temps de réponse
Exigé par des portails (vers votre service) comme Yahoo
QoS pondérée pour différentes classes d’usagers (gold, silver, …)
Évolution incrémentale de la ferme (parc) de serveurs

Didier Donsez, 1995-2010, HTTP

Disponibilité
Tolérance aux pannes
Différents niveaux de disponibilité
fonctionnement dégradé en cas de panne
Le serveur Europe reçoit les requêtes des clients français
Failover : Interruption de service
Basculement d’une session vers un autre serveur sans interruption de
service

Voir:
V. Cardellini, M. Colajanni, P.S.Yu, Dynamic Load Balancing on WebServer Systems, IEEE Internet Computing, May-June 1999, pp28-39
Swaminathan Sivasubramanian, Michal Szymaniak, Guillaume Pierre,
Maarten van Steen, Replication for web hosting systems. ACM Computing
Surveys, Vol 36, N° 2004 ,pp 291-334
3,
119
01/01/2010

Répartition de Charge (Load
Balancing)
Architecture
Un serveur de répartition de charge
Une ferme de serveurs Web
Serveur
WWW
Gold France

Didier Donsez, 1995-2010, HTTP

100
Client WWW
Gold France
10000
Client WWW
France
10000
Client WWW
Allemagne

Serveur
de Répartition
de Charge

Serveur
WWW
France
Serveur
WWW
Europe

Information sur la charge et les pannes

120
01/01/2010

Disponibilité (Avaibility)
Cas d’une panne
Les clients français sont servis par le serveur Europe
La panne peut être détectée par des pings réguliers !
Serveur
WWW
Gold France

Didier Donsez, 1995-2010, HTTP

Client WWW
Gold France
Client WWW
France
Client WWW
Allemagne

Serveur
de Répartition
de Charge

Serveur
WWW
France
Serveur
WWW
Europe

Information sur la charge et les pannes

121
01/01/2010

FailOver
Ininterruption de service
Reprise de la session par un autre nœud du cluster

Solutions
Réplication de données de HttpSession entre les nœuds

Technologies
Données de session persistantes (BD, Fichiers)
Didier Donsez, 1995-2010, HTTP

IO traffic bottleneck

In memory Replication (Communication de Groupes)
Voir article Clustering, theServerSide, April 2002
JavaGroup (reliable and synchronous multicast)

122
01/01/2010

Serveur de Répartition de Charge
Fonction
répartir les requêtes entre les serveurs Web (entre les serveurs
applicatifs)

Politiques de répartition

Didier Donsez, 1995-2010, HTTP

donneur de cartes ([weighted Round Robin])
aléatoire
vers les serveurs les moins chargés
topologique
Optimiser la bande passante de l’infrastructure réseau
L’entreprise dispose de serveurs répartis sur plusieurs backbones
du Web

en fonction de la classe d’usagers
Offrir différentes QoS (temps de réponse, …)

en fonction des sessions en cours
Une session démarrée sur un serveur doit continuer sur ce serveur
SSL, Cookies de session pour Http, Stream du RealServer, …

Fournisseurs

123

Alteon WebSystems, F5, Foundry Networks, Radware, CISCO, …
01/01/2010

Niveaux de la Répartition de Charge
par le Serveur de Répartition (i)
Niveau 3 – IP
Répartition par le DNS
La résolution DNS n’est pas une constante (Round-Robin DNS,
GeoDNS)
une adresse DNS correspond une liste d’adresses IP
à tester nslookup plusieurs fois de suite sur www.sun.com

Didier Donsez, 1995-2010, HTTP

Future RFP VRRP (Virtual Router Redondancy
Protocol)
Grappe de routeurs derrière un routeur virtuel
Adresse MAC sur LAN
Adresse IP sur WAN

Niveau 4 (TCP-Router)
Session SSL
124
01/01/2010

Niveaux de la Répartition de Charge
par le Serveur de Répartition (ii)
Niveau 7 – Applicatif
Protocole HTTP
Détection du Cookie de la classe d’usager dans une requête HTTP
Détection du Cookie de l’identifiant de session dans une requête HTTP

Protocoles FTP, SMTP, …
Flux Audio/Vidéo, …

Rappel : Redirection (301) de la requête HTTP

Didier Donsez, 1995-2010, HTTP

Aisement intégrable à une webapp JavaEE grâce au
javax.servlet.Filter

En savoir plus
Valeria Cardellini, Michele Colajanni, Philip S. Yu: Dynamic Load Balancing on
Web-Server Systems. IEEE Internet Computing 3 (3): 28-39 (1999)
Valeria Cardellini, Emiliano Casalicchio, Michele Colajanni, Philip S. Yu: The state
of the art in locally distributed Web-server systems. ACM Comput. Surv. 34 (2): 263311 (2002)
125
01/01/2010

Performance grâce aux caches
2 types de page
Dynamique
Le contenu varie à chaque requête
Le contenu peut rester constante pour un client au cours de sa session

Statique
Le contenu ne varie pas jusqu’à la prochaine modification
Exemple : Mise à jour des nouvelles du jour tous les matins à
7H00 GMT

Didier Donsez, 1995-2010, HTTP

Les caches
dans les proxys et dans les navigateurs
utilise la date d’expiration du document

Conseil
Pour éviter que le navigateur recharge le document inutile (ce qui
charge le serveur), configurez les dates d’expiration des documents
sur le serveur Web et dans les entêtes des réponses des scripts.
126
01/01/2010

Les Moteurs d ’Indexation (1/2)
L ’utilisateur utilise deux modes de parcours d ’un site
Le suivi de liens
La recherche Full-Text par combinaison de mots-clé et de concepts
(antoine NEAR(15) cléopatre) AND NOT césar

Recherche Plein Texte (Full-Text)
pré-indexation du corpus documentaire
Remarque : le corpus peut provenir du Web (i.e. Portails)
Problème : les documents générés à la volée

Didier Donsez, 1995-2010, HTTP

le script /cgi-bin/search interroge l ’index généré en Offline
1- GET /cgi/search?q=donsez

2- Liste de ref
Client
HTML

3- GET ref

4- ref
Online

Serveur
HTTPD

Copie
Publiée
Index

Indexeur
FullText
Index en
Mise
à Jour Génération

Offline

127
01/01/2010

Les Moteurs d ’Indexation (2/2)
Indexeurs (gratuit ou payant)
FreeWAIS, Glimpse, ht://Dig, Harvest, AltaVista, Verity Search, AIRS,
Basis, Oracle Context, Doris-Floras, RetrievalWare, Virage, QBIC, Google,
Jakarta lucene, …

Caractéristiques
Indexation incrémentale vs totale
l’ajout d ’un document au corpus ne nécessite pas de reconstruire
l ’index

Types de document indexés

Didier Donsez, 1995-2010, HTTP

Texte, Texte structuré
Multimédia : Images, Sons, Vidéo (MPEG7), Monde 3D …

Formats de document analysés
HTML, XML, PDF, Word/RTF, GIF, JPEG, MPEG, ...

Bibliographie
C. Leloup, “Moteurs d'Indexation et de Recherche”, Ed. Eyrolles, 1998,
ISBN 2-212-08976-7

Remarque: Google Desktop Search
indexation des volumes locaux, plugins tiers additionnables

128
01/01/2010

Les Antéserveurs (i)
Documents générés à la volée
nécessite de bonne performance
du serveur HTTP et du serveur BD
Coût des requêtes SQL auprès du
serveur BD

Didier Donsez, 1995-2010, HTTP

1- requête
HTTP
Client
HTML

4- réponse
HTML

2-requête
SQL
Serveur Serveur
HTTPD Applicatif

3-Table
SQL

SGBD
OLTP

BD

Online
129
01/01/2010

Les Antéserveurs (ii)
Cache des résultats (page HTML)
des requêtes SQL fréquemment posées

Terme:
Remarque : importance des informations de cache Edge Computing
dans les entêtes de réponse HTTP

Didier Donsez, 1995-2010, HTTP

Client
HTML

1- requête HTTP

2

Reverse
6- réponse HTML
Proxy(s)
/
7- même
Edge
requête HTTP Servers

Autre Client
9- réponse HTML
HTML

8

5

6

Cache
Online

Serveur
HTTPD 3- Requête SQL
SGBD
+
Serveur 4- Table SQL
Applicatif
Invalidation d’une partie
des objets cachés en cas
de maj de la BD

BD

130
01/01/2010

Les Antéserveurs (iii)
Génération à intervalle régulier d ’une base documentaire à
partir d ’une base de données
Cas de données à faible variation et à caractère non
transactionnelle
Exemple : Catalogue de Produits remis à jour une fois par jour
Requêtes SQL
Batch

SGBD

BD

Didier Donsez, 1995-2010, HTTP

Tables SQL
Copie en
Génération

1- requête
HTTP
Client
HTML

2- réponse
HTML
Online

Serveur
HTTPD

Mise à Jour
Copie
Publiée

Offline
Pressage,Gravage, ...
Copie distribuée sur
support physique
(DK,CD,DVD, …)

131
01/01/2010

Les Antéserveurs (iv)
Génération et
Indexation Full-Text

Requêtes SQL
Batch

SGBD

BD

Tables SQL

Mise à Jour

Didier Donsez, 1995-2010, HTTP

Copie en
Génération

1- requête
HTTP
Client
HTML

2- réponse
HTML
Online

Serveur
HTTPD

Indexeur
FullText
Index

Offline

Copie
Publiée
Index
132
01/01/2010

Embedded Web Server (i)
Rappel : HTTP est un protocole très répandu et très
outillé

Motivation

Didier Donsez, 1995-2010, HTTP

Dialoguer (piloter/administrer) avec des ordinateurs
enfouis ou embarqués via HTTP
Réseaux
Routeurs, Coupleur réseaux domestiques (X10, Echelon,
…) ou industriels (ModBus, …) ..
Electronic consuming
Téléphonie cellulaire, Répondeur domestique, …
Domotique
Proxy Domotique pilotant l’alarme, le chauffage, Frigidaire
…
Entertainement Network (UPnP) …
TV, HIFI, Digital Camera, Consoles de Jeux, WiFi Toys … 133
01/01/2010

Embedded Web Server (ii)
Serveur HTTP
pour ordinateurs enfouis ou embarqués
Empreinte mémoire réduite, CPU
Passerelle OSGi (www.osgi.org) voir cours sur OSGi
Sun’ JES (Java Embedded Server), OSCAR, …

Didier Donsez, 1995-2010, HTTP

Brazil Project, Apache PicoServer, ACME micro_httpd,
TINIWebServer …

HTTP sur « Silicium »
Couches IP/TPC/HTTP directement incluses dans des
DSP, …
134
01/01/2010

Embedded Web Server (iii)
milliers de
millions de
capteurs/actionneurs passerelles
frontières

Internet

mesures agrégées
ou alarmes
par milliers
commandes
par milliers

serveurs
applicatif
requêtes
par milliers

serveur
bases de
données
requêtes
par milliers

Didier Donsez, 1995-2010, HTTP

mesures par
millions

Serveurs HTTP embarqués
•passerelles domotiques,
•passerelles immotiques,
•passerelles véhiculaires,
•passerelles industriels, …

135
01/01/2010

Serveurs Dédiés (ou Server
Appliances)
Motivations
S’oppose aux serveurs généralistes
Configurations matérielles et logicielles dédiées aux services Web
OS: généralement un Linux « tuné », …
HTTPD : Apache, …
configuration Plug-and-Play et administration simple (console HTML,
SMTP)
Enpilable, Rackable, …

Cibles : ISP et PME/PMI
Didier Donsez, 1995-2010, HTTP

Préconfiguration, configuration aisée, …

Fonctionnalités
HTTPD, Proxy, Cache, Firewall, Répartiteur de Charge, AntiVirus,
Messagerie, …
Mais aussi SGBD (Oracle), MediaCaster, Indexeur (Google
Appliances) …

Acteurs
Cobalt (racheté par Sun), RightVision, Akamai et HP, IBM, …

136
01/01/2010

Clients HTTP dans le J2SE et J2ME
Implémente directement un client HTTP
J2SE et J2ME
java.net.URL, java.net.URLConnection, java.net.HttpURLConnection
javax.microedition.io.Connection, javax.microedition.io.HttpConnexion
Jakarta HttpClient
Tache Jakarta Ant/Nant <get> (<post> http://ant-contrib.sourceforge.net)

Fonctionnalités

Didier Donsez, 1995-2010, HTTP

Suivi de session (indépendance de cookies serveurs), multipart
request, WebDav (PUT,DELETE, LOCK, …), HTTP/SSL …

Quelques Usages
Robot de récupération, Injection de charge ...
Déploiement automatique (Ant,Maven,WebDav)
Tunneling HTTP, RPC sur HTTP (XMLRPC, SOAP/HTTP, JMX
Adaptor)

Voir le cours « Programmation Réseau en Java »
137
01/01/2010

HTTP dans HTML (i)
Eléments META dans l ’élément HEAD d ’un
document HTML 3.2
<META HTTP-EQUIV=name CONTENT=value>
équivalent à ajouter des Header ’s
pour documents statiques

Didier Donsez, 1995-2010, HTTP

<META HTTP-EQUIV="Expires" CONTENT=" Tue, 20 Aug 1996 14:25:27 GMT">
<META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com ">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
<META HTTP-EQUIV ="Content-Type" content="text/html; charset=iso-8859-1">
<META HTTP-EQUIV ="Set-Cookie" content="cookie=set; path=/">

Exemple
<HTML><HEAD>
<META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com ">
</HEAD><BODY>
<H1> This site moves to <A HREF=" http://newsite.mycomp.com "> http://newsite.mycomp.com
</A></H1>
</BODY></HTML>
138
01/01/2010

HTTP dans HTML (ii)
Eléments META dans l ’élément HEAD d ’un
document HTML 3.2
<META HTTP-EQUIV=name CONTENT=value>
équivalent à ajouter des Header ’s
pour documents statiques

Didier Donsez, 1995-2010, HTTP

<META HTTP-EQUIV="Expires" CONTENT=" Tue, 20 Aug 1996 14:25:27 GMT">
<META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com ">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
<META HTTP-EQUIV ="Content-Type" content="text/html; charset=iso-8859-1">
<META HTTP-EQUIV ="Set-Cookie" content="cookie=set; path=/">

Exemple
<HTML><HEAD>
<META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com ">
</HEAD><BODY>
<H1> This site moves to <A HREF=" http://newsite.mycomp.com "> http://newsite.mycomp.com
</A></H1>
</BODY></HTML>
139
01/01/2010

HTTP dans HTML (iii)
AJAX (Asynchronous JavaScript Technology and XML)
Objet Javascript XMLHttpRequest
permet d’invoquer des requêtes GET ou POST
l’arbre DOM du résultat (XML ou HTML) peut être parcouru
par le script

Exemple

Didier Donsez, 1995-2010, HTTP

TODO

140
01/01/2010

WAP et WML
Motivation
Adapter HTTP et HTML aux « handsets » nomades
Affichage limité, contrôle limité (i.e. clavier, pointage, …)
Débit limité et coût de communication

WAP Wireless Application Protocol

Didier Donsez, 1995-2010, HTTP

protocole HTTP « like » et « light »
Utilise les couches réseaux des réseaux cellulaires (à la place
d ’IP)
Utilise la sécurité des réseaux cellulaires

WML Wireless Markup Language
langage hypertextuel adapté aux handsets nomades
basé sur XML/DTD : il existe un format plus compact (bytecodé)

voir www.wapforum.org et le cours sur WAP et WML

141
01/01/2010

WAP
Architecture Réseau
WML/HTTP
WML/WAP

Passerelle
WAP

Didier Donsez, 1995-2010, HTTP

Réseau GSM

Serveur
WWW

WML/HTTP

Filtre

Internet

HTML
HTTP

Serveur
WWW

WML/WAP

Filtre
ProxyWAP

WML/WAP

Serveur
TeleVAS

HTML
HTTP

Serveur
WWW

WML/WAP

WAP
Handsets

142
01/01/2010

Faire du PUSH avec HTTP
Motivation : le Push
Une donnée sur le serveur change de valeur
Le navigateur doit charger un document (généré) présentant la
nouvelle valeur

Problème
Le serveur ne peut notifier le navigateur du changement

Solution : le Polling
Didier Donsez, 1995-2010, HTTP

1.

Le navigateur recharge le document régulièrement
Inconvénient: le réaffichage du document pertube l’utilisateur même si
rien de nouveau arrive

<META HTTP-EQUIV="Refresh" CONTENT="5">
2.
Une applet nichée scrute régulièrement auprès du serveur si la
valeur à changer et provoque le rechargement de la page en cas
de changement
Remarque: la valeur du Refresh peut être adaptée au cours du temps

144
01/01/2010

Constrained Application Protocol (CoAP)
Motivation : HTTP/REST-like protocol for constrained sensors
128KB FlashRAM and 4KB RAM
Battery consumption (sleep and periodical wakeup)

Interaction
Request-response
Subscribe-Notify

REST (READ, WRITE, CREATE, DESTROY)
Resource discovery
/profile URI multicast + DISCOVER method

Protocol binding
Didier Donsez, 1995-2010, HTTP

UDP and UDP Multicast (16-bit sequence number for reliability)
Optionally TCP without “stop and wait”

Caching
Important since sleeping mode
CoAP proxy (for subscription …)
See http://www.ietf.org/id/draft-shelby-6lowapp-coap-00.txt
145
01/01/2010

Web 2.0 (TODO)
Motivations

Didier Donsez, 1995-2010, HTTP

Composer l’interface de plusieurs sources fournisseurs
Rendre les interfaces riches et fluides

146
01/01/2010

Technologies RIA (Rich Internet
Application)
Motivations

Didier Donsez, 1995-2010, HTTP

Constat : taux élevé des abandons lors d’une navigation
sur les sites de e-Commerce
Raisons (d’après une étude de Global Millennia
Marketing)
High shipping cost (69%)
Change of mind (61%)
High total cost (49%)
Long checkout process (41%)
Poor site navigation and long download times (31%)
Confusing checkout process (27%)

Solutions
DHTML/AJAX, Flash, OpenLaszlo, … + RESTFul,
JSON, …
147
01/01/2010

The Bayeux protocol
Motivation
« bi-directional » HTTP-based messaging for RIA
Operation invocation RIA
server
data source, RESTful, SOAP, …
Notification Server
RIA
state change, alert, completed Future object …

Didier Donsez, 1995-2010, HTTP

Principe
Pull
Polling

Implementations
JavaScript : Dojo’cometd
…
148
01/01/2010

Bibliographie
Beaucoup de Guides, Tutoriels, Manuels

Didier Donsez, 1995-2010, HTTP

http://ds.internic.net/rfc/rfc2068.txt
http://www.w3.org
http://fr.wikipedia.org/wiki/Hypertext_Transfer_Protocol

Des livres
Attention, ca change très vite !
La traduction en français a au moins 1 an de
retard sur la version anglaise

149
01/01/2010

Bibliographie - HTTP
Stephen Spainhour & Robert Eckstein, « Webmaster in a
Nutshell », 2nd Edition, June 1999 (est.), ISBN 1-56592325-1, Ed : O'Reilly
très complet

Clinton Wong, « Programmation de clients Web avec
Perl », Ed Oreilly, 1997, ISBN 2-84177-050-8

Didier Donsez, 1995-2010, HTTP

l ’automatisation de requêtes sur HTTP (en Perl) Revues

Duane Wessels , Web Caching, June 2001, Oreilly, 156592-536-X
Patrick Killelea , Web Performance Tuning, 1st Edition
October 1998, ISBN 1-56592-379-0
Revue IEEE Internet Computing
http://www.computer.org/internet
Revue IEEE IT Professional http://www.computer.org/itpro
150
01/01/2010

Bibliographie - Serveurs

Didier Donsez, 1995-2010, HTTP

Jason Brittain, Ian F. Darwin, "Tomcat: The Definitive
Guide", Ed OReilly, June 2003, ISBN: 0-596-00318-8

151
01/01/2010

Bibliographie - Autres
Robert Orfali, Dan Harkey, Jeri Edwards, « Client/Server Survival
Guide », 3rd edition, February 1999, Ed John Wiley & Sons; ISBN:
0471316156
information générale sur les composants d ’un SI

Didier Donsez, 1995-2010, HTTP

Louis Rosenfeld, Peter Morville , "Information Architecture for the World
Wide Web - Designing Large-scale Web Sites", 1st Edition February
1998, ISBN 1-56592-282-4,OReilly, 226 pages, $24.95
C. Leloup, “Moteurs d'Indexation et de Recherche”, Ed. Eyrolles, 1998,
ISBN 2-212-08976-7

152
Bonus Track

Más contenido relacionado

La actualidad más candente

Cours php & Mysql - 1ére partie
Cours php & Mysql - 1ére partieCours php & Mysql - 1ére partie
Cours php & Mysql - 1ére partiekadzaki
 
Appalications JEE avec Servlet/JSP
Appalications JEE avec Servlet/JSPAppalications JEE avec Servlet/JSP
Appalications JEE avec Servlet/JSPYouness Boukouchi
 
Cours d'introduction aux HTML5 & CSS3
Cours d'introduction aux HTML5 & CSS3Cours d'introduction aux HTML5 & CSS3
Cours d'introduction aux HTML5 & CSS3Abel LIFAEFI MBULA
 
Laravel 9 comprendre les fondamentaux.
Laravel 9 comprendre les fondamentaux.Laravel 9 comprendre les fondamentaux.
Laravel 9 comprendre les fondamentaux.Valdy Ngouabira
 
Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...
Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...
Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...ENSET, Université Hassan II Casablanca
 
Mise en place du Chattoon en PHP
Mise en place du Chattoon en PHPMise en place du Chattoon en PHP
Mise en place du Chattoon en PHPArmel Diamesso
 
conception et création une base de donnée de réservation de vol
conception et création une base de donnée de réservation de vol conception et création une base de donnée de réservation de vol
conception et création une base de donnée de réservation de vol sara bada
 
Sécurité des Applications WEB -LEVEL1
 Sécurité des Applications WEB-LEVEL1 Sécurité des Applications WEB-LEVEL1
Sécurité des Applications WEB -LEVEL1Tarek MOHAMED
 
Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Faycel Chaoua
 
Support du cours : Programmation Web 2
Support du cours : Programmation Web 2Support du cours : Programmation Web 2
Support du cours : Programmation Web 2Faycel Chaoua
 
Présentation du stage echatibi sofian
Présentation du stage echatibi sofianPrésentation du stage echatibi sofian
Présentation du stage echatibi sofianSofiane Echatibi
 
cours javascript.pptx
cours javascript.pptxcours javascript.pptx
cours javascript.pptxYaminaGh1
 
Sécurité des applications web: attaque et défense
Sécurité des applications web: attaque et défenseSécurité des applications web: attaque et défense
Sécurité des applications web: attaque et défenseAntonio Fontes
 
Conception et Réalisation d’une application de Gestion SCOLAIRE
Conception et Réalisation d’une application de Gestion SCOLAIREConception et Réalisation d’une application de Gestion SCOLAIRE
Conception et Réalisation d’une application de Gestion SCOLAIREGhizlane ALOZADE
 

La actualidad más candente (20)

Cours php & Mysql - 1ére partie
Cours php & Mysql - 1ére partieCours php & Mysql - 1ére partie
Cours php & Mysql - 1ére partie
 
Appalications JEE avec Servlet/JSP
Appalications JEE avec Servlet/JSPAppalications JEE avec Servlet/JSP
Appalications JEE avec Servlet/JSP
 
Cours d'introduction aux HTML5 & CSS3
Cours d'introduction aux HTML5 & CSS3Cours d'introduction aux HTML5 & CSS3
Cours d'introduction aux HTML5 & CSS3
 
Laravel 9 comprendre les fondamentaux.
Laravel 9 comprendre les fondamentaux.Laravel 9 comprendre les fondamentaux.
Laravel 9 comprendre les fondamentaux.
 
Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...
Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...
Mise en oeuvre des Frameworks de Machines et Deep Learning pour les Applicati...
 
Mise en place du Chattoon en PHP
Mise en place du Chattoon en PHPMise en place du Chattoon en PHP
Mise en place du Chattoon en PHP
 
conception et création une base de donnée de réservation de vol
conception et création une base de donnée de réservation de vol conception et création une base de donnée de réservation de vol
conception et création une base de donnée de réservation de vol
 
Sécurité des Applications WEB -LEVEL1
 Sécurité des Applications WEB-LEVEL1 Sécurité des Applications WEB-LEVEL1
Sécurité des Applications WEB -LEVEL1
 
Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2
 
Support du cours : Programmation Web 2
Support du cours : Programmation Web 2Support du cours : Programmation Web 2
Support du cours : Programmation Web 2
 
Support NodeJS avec TypeScript Express MongoDB
Support NodeJS avec TypeScript Express MongoDBSupport NodeJS avec TypeScript Express MongoDB
Support NodeJS avec TypeScript Express MongoDB
 
Présentation du stage echatibi sofian
Présentation du stage echatibi sofianPrésentation du stage echatibi sofian
Présentation du stage echatibi sofian
 
Introduction à Python
Introduction à PythonIntroduction à Python
Introduction à Python
 
Polymorphisme, interface et classe abstraite
Polymorphisme, interface et classe abstraitePolymorphisme, interface et classe abstraite
Polymorphisme, interface et classe abstraite
 
cours javascript.pptx
cours javascript.pptxcours javascript.pptx
cours javascript.pptx
 
Sécurité des applications web: attaque et défense
Sécurité des applications web: attaque et défenseSécurité des applications web: attaque et défense
Sécurité des applications web: attaque et défense
 
Développement d'un site web de E-Commerce avec PHP (Première Partie)
Développement d'un site web de E-Commerce avec PHP (Première Partie)Développement d'un site web de E-Commerce avec PHP (Première Partie)
Développement d'un site web de E-Commerce avec PHP (Première Partie)
 
Support de cours angular
Support de cours angularSupport de cours angular
Support de cours angular
 
Conception et Réalisation d’une application de Gestion SCOLAIRE
Conception et Réalisation d’une application de Gestion SCOLAIREConception et Réalisation d’une application de Gestion SCOLAIRE
Conception et Réalisation d’une application de Gestion SCOLAIRE
 
Support Web Services SOAP et RESTful Mr YOUSSFI
Support Web Services SOAP et RESTful Mr YOUSSFISupport Web Services SOAP et RESTful Mr YOUSSFI
Support Web Services SOAP et RESTful Mr YOUSSFI
 

Destacado

Tutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASH
Tutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASHTutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASH
Tutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASHCyril Concolato
 
Introduction to HTTP protocol
Introduction to HTTP protocolIntroduction to HTTP protocol
Introduction to HTTP protocolAviran Mordo
 
HyperText Transfer Protocol (HTTP)
HyperText Transfer Protocol (HTTP)HyperText Transfer Protocol (HTTP)
HyperText Transfer Protocol (HTTP)Gurjot Singh
 
ASFWS 2011 - L’importance du protocole HTTP dans la menace APT
ASFWS 2011 - L’importance du protocole HTTP dans la menace APTASFWS 2011 - L’importance du protocole HTTP dans la menace APT
ASFWS 2011 - L’importance du protocole HTTP dans la menace APTCyber Security Alliance
 
[FR] Les requêtes HTTP de l'extrême
[FR] Les requêtes HTTP de l'extrême[FR] Les requêtes HTTP de l'extrême
[FR] Les requêtes HTTP de l'extrêmeOVHcloud
 
iPhone & iOS - Introduction au développement d'applications natives
iPhone & iOS - Introduction au développement d'applications nativesiPhone & iOS - Introduction au développement d'applications natives
iPhone & iOS - Introduction au développement d'applications nativesFabrice Delhoste
 
HTTP/2 Changes Everything
HTTP/2 Changes EverythingHTTP/2 Changes Everything
HTTP/2 Changes EverythingLori MacVittie
 
Web API & Cache, the HTTP way - Ippevent 10 Juin 2014
Web API & Cache, the HTTP way - Ippevent 10 Juin 2014Web API & Cache, the HTTP way - Ippevent 10 Juin 2014
Web API & Cache, the HTTP way - Ippevent 10 Juin 2014Ippon
 
Devoxx Maroc 2015 HTTP 1, HTTP 2 and folks
Devoxx Maroc  2015 HTTP 1, HTTP 2 and folksDevoxx Maroc  2015 HTTP 1, HTTP 2 and folks
Devoxx Maroc 2015 HTTP 1, HTTP 2 and folksNicolas Martignole
 

Destacado (12)

Tutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASH
Tutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASHTutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASH
Tutoriel sur le streaming vidéo sur HTTP et sur MPEG-DASH
 
Introduction to HTTP protocol
Introduction to HTTP protocolIntroduction to HTTP protocol
Introduction to HTTP protocol
 
HyperText Transfer Protocol (HTTP)
HyperText Transfer Protocol (HTTP)HyperText Transfer Protocol (HTTP)
HyperText Transfer Protocol (HTTP)
 
ASFWS 2011 - L’importance du protocole HTTP dans la menace APT
ASFWS 2011 - L’importance du protocole HTTP dans la menace APTASFWS 2011 - L’importance du protocole HTTP dans la menace APT
ASFWS 2011 - L’importance du protocole HTTP dans la menace APT
 
[FR] Les requêtes HTTP de l'extrême
[FR] Les requêtes HTTP de l'extrême[FR] Les requêtes HTTP de l'extrême
[FR] Les requêtes HTTP de l'extrême
 
Facebook & Twitter API
Facebook & Twitter APIFacebook & Twitter API
Facebook & Twitter API
 
iPhone & iOS - Introduction au développement d'applications natives
iPhone & iOS - Introduction au développement d'applications nativesiPhone & iOS - Introduction au développement d'applications natives
iPhone & iOS - Introduction au développement d'applications natives
 
APACHE TOMCAT
APACHE TOMCATAPACHE TOMCAT
APACHE TOMCAT
 
Http Vs Https .
Http Vs Https . Http Vs Https .
Http Vs Https .
 
HTTP/2 Changes Everything
HTTP/2 Changes EverythingHTTP/2 Changes Everything
HTTP/2 Changes Everything
 
Web API & Cache, the HTTP way - Ippevent 10 Juin 2014
Web API & Cache, the HTTP way - Ippevent 10 Juin 2014Web API & Cache, the HTTP way - Ippevent 10 Juin 2014
Web API & Cache, the HTTP way - Ippevent 10 Juin 2014
 
Devoxx Maroc 2015 HTTP 1, HTTP 2 and folks
Devoxx Maroc  2015 HTTP 1, HTTP 2 and folksDevoxx Maroc  2015 HTTP 1, HTTP 2 and folks
Devoxx Maroc 2015 HTTP 1, HTTP 2 and folks
 

Similar a Le protocole HTTP

Introduction au web cours.pdf
Introduction au web cours.pdfIntroduction au web cours.pdf
Introduction au web cours.pdfElomyakobi
 
Examen
Examen Examen
Examen TECOS
 
Presentation
PresentationPresentation
Presentationbois
 
JEE_chapitre 1.pdf
JEE_chapitre 1.pdfJEE_chapitre 1.pdf
JEE_chapitre 1.pdfiyadamri
 
Drupal 8, symfony
Drupal 8, symfonyDrupal 8, symfony
Drupal 8, symfonyjeUXdiCode
 
Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !Olivier Le Goaër
 
alphorm.com - Formation Exchange Server 2013 (70-341)
alphorm.com - Formation Exchange Server 2013 (70-341)alphorm.com - Formation Exchange Server 2013 (70-341)
alphorm.com - Formation Exchange Server 2013 (70-341)Alphorm
 
Ch3_Couche application.pptx
Ch3_Couche application.pptxCh3_Couche application.pptx
Ch3_Couche application.pptxOthmaneMansouri1
 
intro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdfintro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdfCoumbaLaobNdiaye1
 
Resource Oriented Architecture
Resource Oriented ArchitectureResource Oriented Architecture
Resource Oriented ArchitectureDNG Consulting
 
Projet sur transfert de fichiers
Projet sur transfert de fichiersProjet sur transfert de fichiers
Projet sur transfert de fichiersjosepkap
 

Similar a Le protocole HTTP (20)

spring.pdf
spring.pdfspring.pdf
spring.pdf
 
Aet pow isi_2017_chp3
Aet pow isi_2017_chp3Aet pow isi_2017_chp3
Aet pow isi_2017_chp3
 
Introduction au web cours.pdf
Introduction au web cours.pdfIntroduction au web cours.pdf
Introduction au web cours.pdf
 
Support JEE Servlet Jsp MVC M.Youssfi
Support JEE Servlet Jsp MVC M.YoussfiSupport JEE Servlet Jsp MVC M.Youssfi
Support JEE Servlet Jsp MVC M.Youssfi
 
Technologie Web.pptx
Technologie Web.pptxTechnologie Web.pptx
Technologie Web.pptx
 
Examen
Examen Examen
Examen
 
Chapitre 1.pdf
Chapitre 1.pdfChapitre 1.pdf
Chapitre 1.pdf
 
technologie web
technologie webtechnologie web
technologie web
 
Presentation
PresentationPresentation
Presentation
 
Sip
SipSip
Sip
 
JEE_chapitre 1.pdf
JEE_chapitre 1.pdfJEE_chapitre 1.pdf
JEE_chapitre 1.pdf
 
Drupal 8, symfony
Drupal 8, symfonyDrupal 8, symfony
Drupal 8, symfony
 
Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !
 
INTRODUCTION8PDF.pdf
INTRODUCTION8PDF.pdfINTRODUCTION8PDF.pdf
INTRODUCTION8PDF.pdf
 
alphorm.com - Formation Exchange Server 2013 (70-341)
alphorm.com - Formation Exchange Server 2013 (70-341)alphorm.com - Formation Exchange Server 2013 (70-341)
alphorm.com - Formation Exchange Server 2013 (70-341)
 
Ch3_Couche application.pptx
Ch3_Couche application.pptxCh3_Couche application.pptx
Ch3_Couche application.pptx
 
intro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdfintro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdf
 
Ns python web 1
Ns python web 1Ns python web 1
Ns python web 1
 
Resource Oriented Architecture
Resource Oriented ArchitectureResource Oriented Architecture
Resource Oriented Architecture
 
Projet sur transfert de fichiers
Projet sur transfert de fichiersProjet sur transfert de fichiers
Projet sur transfert de fichiers
 

Más de Souhaib El

Comment votre pc peut il être piraté sur internet
Comment votre pc peut il être piraté sur internetComment votre pc peut il être piraté sur internet
Comment votre pc peut il être piraté sur internetSouhaib El
 
Les Réseaux sans fils 802.11
 Les Réseaux sans fils 802.11 Les Réseaux sans fils 802.11
Les Réseaux sans fils 802.11Souhaib El
 
Exchange Server 2010
Exchange Server 2010Exchange Server 2010
Exchange Server 2010Souhaib El
 
service NFS sous linux
 service NFS sous linux service NFS sous linux
service NFS sous linuxSouhaib El
 
SSH - Secure Shell
SSH - Secure ShellSSH - Secure Shell
SSH - Secure ShellSouhaib El
 
Réseau sans fil technologie wi-fi
Réseau sans fil technologie wi-fiRéseau sans fil technologie wi-fi
Réseau sans fil technologie wi-fiSouhaib El
 
Système d’exploitation: Principe
Système d’exploitation: PrincipeSystème d’exploitation: Principe
Système d’exploitation: PrincipeSouhaib El
 
DNS sous linux
DNS sous linuxDNS sous linux
DNS sous linuxSouhaib El
 
Securite informatique
Securite informatiqueSecurite informatique
Securite informatiqueSouhaib El
 
Securite informatique
Securite informatiqueSecurite informatique
Securite informatiqueSouhaib El
 
DHCP sous Ubuntu
DHCP sous Ubuntu DHCP sous Ubuntu
DHCP sous Ubuntu Souhaib El
 
DHCP sous fedora
DHCP sous fedora DHCP sous fedora
DHCP sous fedora Souhaib El
 
installation et configuration du DNS sous Windows serveur 2003
installation et configuration du DNS sous Windows serveur 2003installation et configuration du DNS sous Windows serveur 2003
installation et configuration du DNS sous Windows serveur 2003Souhaib El
 
les Commandes linux/Unix (giants networks)
les Commandes linux/Unix (giants networks)les Commandes linux/Unix (giants networks)
les Commandes linux/Unix (giants networks)Souhaib El
 
Qcm serveur 2003 souhaib el
Qcm serveur 2003 souhaib elQcm serveur 2003 souhaib el
Qcm serveur 2003 souhaib elSouhaib El
 

Más de Souhaib El (16)

Comment votre pc peut il être piraté sur internet
Comment votre pc peut il être piraté sur internetComment votre pc peut il être piraté sur internet
Comment votre pc peut il être piraté sur internet
 
Les Réseaux sans fils 802.11
 Les Réseaux sans fils 802.11 Les Réseaux sans fils 802.11
Les Réseaux sans fils 802.11
 
Exchange Server 2010
Exchange Server 2010Exchange Server 2010
Exchange Server 2010
 
Supervision
SupervisionSupervision
Supervision
 
service NFS sous linux
 service NFS sous linux service NFS sous linux
service NFS sous linux
 
SSH - Secure Shell
SSH - Secure ShellSSH - Secure Shell
SSH - Secure Shell
 
Réseau sans fil technologie wi-fi
Réseau sans fil technologie wi-fiRéseau sans fil technologie wi-fi
Réseau sans fil technologie wi-fi
 
Système d’exploitation: Principe
Système d’exploitation: PrincipeSystème d’exploitation: Principe
Système d’exploitation: Principe
 
DNS sous linux
DNS sous linuxDNS sous linux
DNS sous linux
 
Securite informatique
Securite informatiqueSecurite informatique
Securite informatique
 
Securite informatique
Securite informatiqueSecurite informatique
Securite informatique
 
DHCP sous Ubuntu
DHCP sous Ubuntu DHCP sous Ubuntu
DHCP sous Ubuntu
 
DHCP sous fedora
DHCP sous fedora DHCP sous fedora
DHCP sous fedora
 
installation et configuration du DNS sous Windows serveur 2003
installation et configuration du DNS sous Windows serveur 2003installation et configuration du DNS sous Windows serveur 2003
installation et configuration du DNS sous Windows serveur 2003
 
les Commandes linux/Unix (giants networks)
les Commandes linux/Unix (giants networks)les Commandes linux/Unix (giants networks)
les Commandes linux/Unix (giants networks)
 
Qcm serveur 2003 souhaib el
Qcm serveur 2003 souhaib elQcm serveur 2003 souhaib el
Qcm serveur 2003 souhaib el
 

Último

DIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptx
DIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptxDIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptx
DIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptxMartin M Flynn
 
Bibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdf
Bibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdfBibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdf
Bibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdfBibdoc 37
 
Newsletter SPW Agriculture en province du Luxembourg du 10-04-24
Newsletter SPW Agriculture en province du Luxembourg du 10-04-24Newsletter SPW Agriculture en province du Luxembourg du 10-04-24
Newsletter SPW Agriculture en province du Luxembourg du 10-04-24BenotGeorges3
 
PIE-A2-P 5- Supports stagiaires.pptx.pdf
PIE-A2-P 5- Supports stagiaires.pptx.pdfPIE-A2-P 5- Supports stagiaires.pptx.pdf
PIE-A2-P 5- Supports stagiaires.pptx.pdfRiDaHAziz
 
Bibdoc 2024 - Les intelligences artificielles en bibliotheque.pdf
Bibdoc 2024 - Les intelligences artificielles en bibliotheque.pdfBibdoc 2024 - Les intelligences artificielles en bibliotheque.pdf
Bibdoc 2024 - Les intelligences artificielles en bibliotheque.pdfBibdoc 37
 
Pas de vagues. pptx Film français
Pas de vagues.  pptx   Film     françaisPas de vagues.  pptx   Film     français
Pas de vagues. pptx Film françaisTxaruka
 
Faut-il avoir peur de la technique ? (G. Gay-Para)
Faut-il avoir peur de la technique ? (G. Gay-Para)Faut-il avoir peur de la technique ? (G. Gay-Para)
Faut-il avoir peur de la technique ? (G. Gay-Para)Gabriel Gay-Para
 
Pas de vagues. pptx Film français
Pas de vagues.  pptx      Film   françaisPas de vagues.  pptx      Film   français
Pas de vagues. pptx Film françaisTxaruka
 
Bernard Réquichot.pptx Peintre français
Bernard Réquichot.pptx   Peintre françaisBernard Réquichot.pptx   Peintre français
Bernard Réquichot.pptx Peintre françaisTxaruka
 
Présentation - Initiatives - CECOSDA - OIF - Fact Checking.pptx
Présentation - Initiatives - CECOSDA - OIF - Fact Checking.pptxPrésentation - Initiatives - CECOSDA - OIF - Fact Checking.pptx
Présentation - Initiatives - CECOSDA - OIF - Fact Checking.pptxJCAC
 
PIE-A2-P4-support stagiaires sept 22-validé.pdf
PIE-A2-P4-support stagiaires sept 22-validé.pdfPIE-A2-P4-support stagiaires sept 22-validé.pdf
PIE-A2-P4-support stagiaires sept 22-validé.pdfRiDaHAziz
 
Apprendre avec des top et nano influenceurs
Apprendre avec des top et nano influenceursApprendre avec des top et nano influenceurs
Apprendre avec des top et nano influenceursStagiaireLearningmat
 
Bibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdf
Bibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdfBibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdf
Bibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdfBibdoc 37
 
Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...
Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...
Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...Bibdoc 37
 
Vulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdf
Vulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdfVulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdf
Vulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdfSylvianeBachy
 
Chana Orloff.pptx Sculptrice franco-ukranienne
Chana Orloff.pptx Sculptrice franco-ukranienneChana Orloff.pptx Sculptrice franco-ukranienne
Chana Orloff.pptx Sculptrice franco-ukranienneTxaruka
 
La Base unique départementale - Quel bilan, au bout de 5 ans .pdf
La Base unique départementale - Quel bilan, au bout de 5 ans .pdfLa Base unique départementale - Quel bilan, au bout de 5 ans .pdf
La Base unique départementale - Quel bilan, au bout de 5 ans .pdfbdp12
 

Último (18)

DIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptx
DIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptxDIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptx
DIGNITAS INFINITA - DIGNITÉ HUMAINE; déclaration du dicastère .pptx
 
Bibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdf
Bibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdfBibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdf
Bibdoc 2024 - Les maillons de la chaine du livre face aux enjeux écologiques.pdf
 
Newsletter SPW Agriculture en province du Luxembourg du 10-04-24
Newsletter SPW Agriculture en province du Luxembourg du 10-04-24Newsletter SPW Agriculture en province du Luxembourg du 10-04-24
Newsletter SPW Agriculture en province du Luxembourg du 10-04-24
 
PIE-A2-P 5- Supports stagiaires.pptx.pdf
PIE-A2-P 5- Supports stagiaires.pptx.pdfPIE-A2-P 5- Supports stagiaires.pptx.pdf
PIE-A2-P 5- Supports stagiaires.pptx.pdf
 
Bibdoc 2024 - Les intelligences artificielles en bibliotheque.pdf
Bibdoc 2024 - Les intelligences artificielles en bibliotheque.pdfBibdoc 2024 - Les intelligences artificielles en bibliotheque.pdf
Bibdoc 2024 - Les intelligences artificielles en bibliotheque.pdf
 
Pas de vagues. pptx Film français
Pas de vagues.  pptx   Film     françaisPas de vagues.  pptx   Film     français
Pas de vagues. pptx Film français
 
Faut-il avoir peur de la technique ? (G. Gay-Para)
Faut-il avoir peur de la technique ? (G. Gay-Para)Faut-il avoir peur de la technique ? (G. Gay-Para)
Faut-il avoir peur de la technique ? (G. Gay-Para)
 
Pas de vagues. pptx Film français
Pas de vagues.  pptx      Film   françaisPas de vagues.  pptx      Film   français
Pas de vagues. pptx Film français
 
Bernard Réquichot.pptx Peintre français
Bernard Réquichot.pptx   Peintre françaisBernard Réquichot.pptx   Peintre français
Bernard Réquichot.pptx Peintre français
 
Présentation - Initiatives - CECOSDA - OIF - Fact Checking.pptx
Présentation - Initiatives - CECOSDA - OIF - Fact Checking.pptxPrésentation - Initiatives - CECOSDA - OIF - Fact Checking.pptx
Présentation - Initiatives - CECOSDA - OIF - Fact Checking.pptx
 
PIE-A2-P4-support stagiaires sept 22-validé.pdf
PIE-A2-P4-support stagiaires sept 22-validé.pdfPIE-A2-P4-support stagiaires sept 22-validé.pdf
PIE-A2-P4-support stagiaires sept 22-validé.pdf
 
Apprendre avec des top et nano influenceurs
Apprendre avec des top et nano influenceursApprendre avec des top et nano influenceurs
Apprendre avec des top et nano influenceurs
 
Bibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdf
Bibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdfBibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdf
Bibdoc 2024 - Sobriete numerique en bibliotheque et centre de documentation.pdf
 
Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...
Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...
Bibdoc 2024 - L’Éducation aux Médias et à l’Information face à l’intelligence...
 
Bulletin des bibliotheques Burkina Faso mars 2024
Bulletin des bibliotheques Burkina Faso mars 2024Bulletin des bibliotheques Burkina Faso mars 2024
Bulletin des bibliotheques Burkina Faso mars 2024
 
Vulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdf
Vulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdfVulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdf
Vulnérabilité numérique d’usage : un enjeu pour l’aide à la réussitepdf
 
Chana Orloff.pptx Sculptrice franco-ukranienne
Chana Orloff.pptx Sculptrice franco-ukranienneChana Orloff.pptx Sculptrice franco-ukranienne
Chana Orloff.pptx Sculptrice franco-ukranienne
 
La Base unique départementale - Quel bilan, au bout de 5 ans .pdf
La Base unique départementale - Quel bilan, au bout de 5 ans .pdfLa Base unique départementale - Quel bilan, au bout de 5 ans .pdf
La Base unique départementale - Quel bilan, au bout de 5 ans .pdf
 

Le protocole HTTP

  • 1. http://membres-liglab.imag.fr/donsez/cours Le protocole HTTP Didier DONSEZ Université Joseph Fourier (Grenoble 1) PolyTech’Grenoble – LIG/ADELE Didier.Donsez@imag.fr Didier.Donsez@ieee.org
  • 2. 01/01/2010 Au sommaire > > > Didier Donsez, 1995-2010, HTTP Historique Le protocole HTTP Les méthodes GET et POST Le suivi de session Clients et Serveurs HTTP Autour d ’HTTP 2
  • 3. 01/01/2010 Le Protocole HTTP HTTP : HyperText Tranfert Protocol (RFC 1945 et 2068) protocole de rapatriement des documents protocole de soumission de formulaires Fonctionnement (très simple en HTTP/1.0) Didier Donsez, 1995-2010, HTTP connexion demande (GET) d ’un document renvoi du document (status=200) ou d ’une erreur déconnexion Cependant dialogue plus complexe en cas d ’identification optimisation : une série de plusieurs requêtes sur une connexion Connexion « KeepAlive » de HTTP/1.1 (RFC 2068) 3
  • 4. 01/01/2010 Un protocole omniscient IT Servers Didier Donsez, 1995-2010, HTTP Embedded Servers 4
  • 5. 01/01/2010 Dialogue HTTP Protocole en mode de lignes de caractère le plus basic de butineur (User Agent) HTTP : telnet www.sun.com 80 Types de dialogue Récupération d ’un document méthode GET Didier Donsez, 1995-2010, HTTP Soumission d ’un formulaire méthodes GET ou POST Envoi de Document et Gestion de Site méthodes PUT, DELETE, LINK, UNLINK Gestion de proxy/cache méthode HEAD (récupération des informations sur le document) 5
  • 6. 01/01/2010 Dialogue HTTP exemple de requête HTTP (méthode POST) Entête de la requête POST /script UA Didier Donsez, 1995-2010, HTTP le Client envoie la Requête HTTPD port 80 machX doc.htm POST /script HTTP/1.0 méthode,chemin,version Accept: www/source documents acceptés Accept: text/html le Serveur retourne la Réponse Accept: image/gif HTTP/1.0 200 OK ligne de status Entête de la Accept: image/jpeg Date: Wed, 02Feb97 23:04:12 GMT réponse User-Agent: Lynx/2.2 libwww/2.14 Server: NCSA/1.1 * une ligne blanche * MIME-version: 1.0 name1=value1& Last-modified: Mon,15Nov96 23:33:16 GMT name2=value2 Content-type: text/html type du document retourné Content-length: 2345 sa taille Corps de la Corps de la * une ligne blanche * réponse requête <HTML><HEAD><TITLE> ... 6
  • 7. 01/01/2010 Format de la requête Envoyé par le client au serveur Didier Donsez, 1995-2010, HTTP <Méthode> <URI> HTTP/<Version> [<Champ d ’entête>: <Valeur>] [<tab><Suite Valeur si >1024>] ligne blanche [corps de la requête pour la méthode POST] GET /docu2.html HTTP/1.0 Accept: www/source Accept: text/html Accept: image/gif User-Agent: Lynx/2.2 libwww/2.14 From: alice@pays.merveilles.net * une ligne blanche * POST /script HTTP/1.0 Accept: www/source Accept: text/html Accept: image/gif User-Agent: Lynx/2.2 libwww/2.14 From: alice@pays.merveilles.net Content-Length: 24 * une ligne blanche * name1=value1& name2=value2 7
  • 8. 01/01/2010 Méthodes de la requête (i) GET demande pour obtenir des informations et une zone de données concernant l ’URI HEAD demande pour seulement obtenir des informations concernant l ’URI POST Didier Donsez, 1995-2010, HTTP envoie de données (contenu du formulaire vers le serveur, requête SOAP …) situées dans le corps. PUT enregistrement du corps de la requête à l ’URI indiqué DELETE suppression des données désignées par l ’URI 8
  • 9. 01/01/2010 Méthodes de la requête (ii) OPTIONS demande des options de communication disponibles TRACE retourne le corps de la requête intacte (déboguage) CONNECT Didier Donsez, 1995-2010, HTTP + Nouvelles extensions de WebDAV > PROPFIND, PROPPATCH, MKCOL,COPY, MOVE, LOCK, UNLOCK + Nouvelles extensions de HTTP/U et HTTP/MU NOTIFY, … (UPnP) 9
  • 10. 01/01/2010 Format de la réponse Didier Donsez, 1995-2010, HTTP Réponse envoyé par le serveur au client HTTP/<Version> <Status> <Commentaire Status> Content-Type: <Type MIME du contenu> [< Champ d ’entête >: <Valeur>] [<tab><Suite Valeur si >1024>] Ligne blanche HTTP/1.0 200 OK Document Date: Wed, 02Feb97 23:04:12 GMT Server: NCSA/1.1 MIME-version: 1.0 Last-modified: Mon,15Nov96 23:33:16 GMT Content-type: text/html Content-length: 2345 * une ligne blanche * <HTML><HEAD><TITLE> … </BODY></HTML> 10
  • 11. 01/01/2010 Status des réponses HTTP (RFC2068) Code de réponse donné par le serveur au client 100-199 Informationnel 100 : Continue (le client peut envoyer la suite de la requête), ... 200-299 Succès de la requête client 200: OK, 201: Created, 204 : No Content, ... 300-399 Redirection de la Requête client Didier Donsez, 1995-2010, HTTP 301: Redirection, 302: Found, 304: Not Modified, 305 : Use Proxy, ... 400-499 Requête client incomplète 400: Bad Request, 401: Unauthorized, 403: Forbidden, 404: Not Found 500-599 Erreur Serveur 500: Server Error, 501: Not Implemented, 502: Bad Gateway, 503: Out Of Resources (Service Unavailable) 11
  • 12. 01/01/2010 Entêtes HTTP 4 types de champs d ’entête Général commun au serveur, au client ou à HTTP Requête du client formats de documents et paramètres pour le serveur Réponse du serveur information concernant le serveur Didier Donsez, 1995-2010, HTTP Entité informations concernant les données échangés 12
  • 13. 01/01/2010 Entêtes Généraux HTTP Cache-Control = contrôle du caching. Connection = listes d ’option Didier Donsez, 1995-2010, HTTP close pour terminer une connexion. Date = date actuelle (format RFC1123 mais aussi RFC850). MIME-Version = version MIME utilisé. Pragma = instruction pour le proxy. Transfer-Encoding = type de la transformation appliquée au corps du message. Upgrade = indique le protocole souhaité. Via = utilisé par les proxys pour indiquer les machines et protocoles intermédiaires. 13
  • 14. 01/01/2010 Entêtes de requêtes client HTTP Accept = type MIME visualisable par l ’agent Accept-Language : liste de langues (fr, en, … ) Authorization = type d ’autorisation BASIC nom:mot de passe (en base64) donc transmis en clair !!! NB : Préalablement le serveur a répondu un WWW-Authenticate Cookie = cookie rétourné Host = spécifie la machine et le port du serveur Didier Donsez, 1995-2010, HTTP un serveur peut héberger plusieurs serveurs Referer = URL d ’origine page à contenant l ’ancre à partir de laquelle le visualisateur a trouvé l ’URL. User-Agent = modèle du visualisateur 14
  • 15. 01/01/2010 Entêtes de requêtes client HTTP From = adresse email de l ’utilisateur rarement envoyé pour conserver l anonymat de l ’utilisateur If-Modified-Since = condition de retrait Didier Donsez, 1995-2010, HTTP la page n ’est transférée que si elle a été modifiée depuis la date précisée. Utilisé par les caches indique si le document demandé peut être caché ou pas. If-Unmodified-Since = condition de retrait If-Match = condition de retrait If-None-Match = condition de retrait If-Range = condition de retrait 15
  • 16. 01/01/2010 Entêtes de requêtes client HTTP Max-Forwards = nombre max de proxy Proxy-Authorization = identification Range = zone du document à renvoyer Didier Donsez, 1995-2010, HTTP bytes=x-y (x=0 correspond au premier octet, y peut être omis pour spécifier jusqu ’à la fin) 16
  • 17. 01/01/2010 Entêtes des réponses serveur HTTP Accept-Range = accepte ou refus d ’une requête par intervalle Age = ancienneté du document en secondes Proxy-Authenticate = système d ’authentification du proxy Public = liste de méthodes non standards gérées par le serveur Retry-After = date ou nombre de secondes pour un ressai en cas de code 503 (service unavailable) Server = modèle de HTTPD Didier Donsez, 1995-2010, HTTP utilisé par Satan !!!! Set-Cookie = créer ou modifie un cookie sur le client Vary = l ’entité possède plusieurs sources Warning = informations supplémentaire du code d ’état 14 Transformation applied : le proxy a changé de Content-Type ou le Content-Encoding WWW-Authenticate = système d ’authentification pour l ’URI 17
  • 18. 01/01/2010 Entêtes d ’entité HTTP Allow = méthodes autorisées pour l ’URI Content-Base = URI de base pour la résolution des URL Last-Modified = date de dernière modification du doc. Utilisé par les caches Content-Length = taille du document en octet utilisé par le client pour gauger la progression des chargements Content-Encoding = type encodage du document renvoyé Didier Donsez, 1995-2010, HTTP compress, x-gzip, x-zip Content-Language : le langage du document retourné fr, en ... Content-Location : URI de l ’entité quand l ’URI est à plusieurs endroits 18
  • 19. 01/01/2010 Entêtes d ’entité HTTP Content-MD5 : résumé MD5 de l ’entité Content-Range : position du corps partiel dans l ’entité bytes x-y/taille Content-Transfert-Encoding : transformation appliqué du corps de l ’entité 7bit, binary, base64, quoted-printable Content-Type = type MIME du document renvoyé Didier Donsez, 1995-2010, HTTP utilisé par le client pour sélectionner le visualisateur (plugin) RFC2045 ETag : transformation appliqué du corps de l ’entité 7bit, binary, base64, quoted-printable Expires : date de péremption de l ’entité Refresh : 10 Refresh: 10; Location=/newloc.htm 19
  • 20. 01/01/2010 Internationalisation Language Accept fr, de, it, en, sq (albanais), ru, (russe), ja (japonais), zh (chinois), el (grec), he (hébreu), ca (catalan) ... Charset (table de caractère) Didier Donsez, 1995-2010, HTTP par défaut ISO-8859-1 (Latin-1) ISO-8859-2 (hongrois, albanais, …) ISO-8859- 4 ISO-8859-5, KOI8-R (russe, bulgare, polonais) ISO-8859-7 (grec) ISO-8859-8 (hébreu) ISO-8859-9 (turc) Shift_JIS, ISO-2022-JP, EUC-JP (japonais) Big5 (chinois simplifié) GB2312(chinois traditionnel - Taiwan) 20
  • 21. 01/01/2010 Récupération d ’un Document Méthode GET GET /doc.htm UA Didier Donsez, 1995-2010, HTTP le Client envoie HTTPD port 80 machX doc.htm GET /doc.htm HTTP/1.0 méthode,chemin,version Accept: www/source documents acceptés Accept: text/html le Serveur répond Accept: image/gif User-Agent: Lynx/2.2 libwww/2.14 HTTP/1.0 200 OK ligne de status Date: Wed, 02Feb97 23:04:12 GMT From: alice@pays.merveilles.net Server: NCSA/1.1 * une ligne blanche * MIME-version: 1.0 Last-modified: Mon,15Nov96 23:33:16 GMT Content-type: text/html type du document retourné Content-length: 2345 sa taille * une ligne blanche * <HTML><HEAD><TITLE> ... 21
  • 22. 01/01/2010 Soumission d ’un Formulaire Méthode GET GET /script?name1=value1&name2=value2 UA Didier Donsez, 1995-2010, HTTP le Client envoie HTTPD port 80 machX script GET /script?name1=value1&name2=value2 HTTP/1.0 Accept: www/source documents acceptés Accept: text/html le Serveur répond Accept: image/gif User-Agent: Lynx/2.2 libwww/2.14 HTTP/1.0 200 OK ligne de status Date: Wed, 02Feb97 23:04:12 GMT From: alice@pays.merveilles.net Server: NCSA/1.1 * une ligne blanche * MIME-version: 1.0 Last-modified: Mon,15Nov96 23:33:16 GMT Content-type: text/html type du document retourné Content-length: 2345 sa taille * une ligne blanche * <HTML><HEAD><TITLE> ... 22
  • 23. 01/01/2010 Soumission d ’un Formulaire Méthode POST POST /script Didier Donsez, 1995-2010, HTTP UA le Client envoie POST /script HTTP/1.0 Accept: www/source Accept: text/html Accept: image/gif User-Agent: Lynx/2.2 libwww/2.14 From: alice@pays.merveilles.net * une ligne blanche * name1=value1& name2=value2 HTTPD port 80 machX script le Serveur répond HTTP/1.0 200 OK … Content-length: 2345 * une ligne blanche * <HTML><HEAD><TITLE> ... 23
  • 24. 01/01/2010 Codage des « paramètres » Les valeurs passées (URL et contenu des entrées des formulaires) doivent être sur 7 bits et sans caractères spéciaux Format d ’encodage : x-www-form-urlencoded Espace Tous les caractères spéciaux et accentués ascii Didier Donsez, 1995-2010, HTTP @ é + %code %40 %e9 Les entrées des formulaires sont encodés dans une chaîne composée de paires (nom de l ’entrée)=(valeur de l ’entrée) séparé par de & nom=Dupont+Jean&adresse=3+rue+de+la+Gait%e9%0a75014+Paris il existe de nombreuses bibliothèques d ’encodage/décodage dans le JDK : static String java.net.URLDecoder.decode(String urlencoded, String encodingscheme) static String java.net.URLEncoder.encode(String str , String encodingscheme) 24
  • 25. 01/01/2010 Comportement du User Agent face au type du document retourné A partir du type MIME de Content-Type Visualisation native la fonction de visualisation est dans le noyau (core) du client text/html, image/jpeg Visualisation par plugin Didier Donsez, 1995-2010, HTTP la fonction est présente dans un DLL, SO, ou un JAR elle est liée dynamiquement pour réaliser la visualisation world/vrml, text/tex Visualisation externe la fonction n ’est pas présente dans le client le client rapporte le document et le sauvegarde dans un fichier temporaire video/mpeg, application/postscript 25
  • 26. 01/01/2010 Requête Multi-parties (multipart) Motivation Didier Donsez, 1995-2010, HTTP Requête multi-document [RFC1867] formulaire HTML contenant des Upload de fichiers <FORM ACTION="/servlet/UploadTest" ENCTYPE="multipart/formdata" METHOD=POST> Your name? <INPUT TYPE=TEXT NAME=submitter> <BR> Your first file to upload? <INPUT TYPE=FILE NAME=file1> <BR> Your second file to upload? <INPUT TYPE=FILE NAME=file2> <BR <INPUT TYPE=SUBMIT> </FORM> Remarque : Mail multi-documents (fichiers attachés, mail enrichi d ’images, audio-mail …) 26
  • 27. 01/01/2010 Requête Multi-parties (multipart) Codage de la requête Une chaîne tirée aléatoirement sert de séparateur Content-Type : multipart/form;boundary=End9989822 --End9989822 Didier Donsez, 1995-2010, HTTP Content-Disposition; form-data; name="file1"; filename="test.htm" Content-Type : text/html <HTML><BODY> Ceci est un fichier de test !</BODY></HTML> --End9989822 Content-Disposition; form-data; name="file2"; filename="test2.txt" Content-Type : text/plain Ceci est un deuxieme fichier de test ! --End9989822 Classes de manipulation (non standard) voir [Hunter Ex4-18 p 107] 27
  • 28. 01/01/2010 Réponse Multi-parties Codage Content-Type : multipart/x-mixed-replace; Frontière entre les parties Déclaration : boundary=chaîne_aléatoire Séparateur : --chaîne_aléatoire Didier Donsez, 1995-2010, HTTP Comportement le navigateur affiche le sous-document suivant dès qu ’il commence à le recevoir après avoir effacer la fenêtre. Voir [Hunter ex6-12 p193] 28
  • 29. 01/01/2010 Réponse Multi-parties Exemple Content-Type : multipart/x-mixed-replace;boundary=End65577565679001838 ligne blanche --End65577565679001838 Le serveur définit une chaîne séparateur des documents Content-Type : text/html ligne blanche <HTML><BODY><H1>Trois … </H1><BODY></HTML> --End65577565679001838 Didier Donsez, 1995-2010, HTTP Content-Type : text/html ligne blanche <HTML><BODY><H1>Deux … </H1><BODY></HTML> --End65577565679001838 Content-Type : text/html ligne blanche <HTML><BODY><H1>Un … </H1><BODY></HTML> --End65577565679001838 Content-Type : text/html ligne blanche <HTML><BODY><H1>Partez ! </H1><BODY></HTML> --End65577565679001838 Le serveur attend 1 seconde avant de renvoyer la suite : le client affiche « Trois… » Le serveur attend 1 seconde avant de renvoyer la suite : le client affiche « Deux… » Le serveur attend 1 seconde avant de renvoyer la suite : le client affiche « Un… » Le serveur clôt la connexion TCP/IP avant de renvoyer la suite : le client affiche finalement « Partez !» 29
  • 30. 01/01/2010 Suivi de Sessions avec HTTP (Session Tracking) Motivations : La notion de session est importante dans une application conversationnelle commerce électronique « j ’ajoute ce produit à mon panier (existant)» Didier Donsez, 1995-2010, HTTP Cependant HTTP est un protocole « stateless » le serveur ne maintient pas d ’informations liées aux requêtes précédentes d ’un même client. HTTP est donc « sessionless » Comment implanter la notion de session sur plusieurs requêtes HTTP documents, CGI, SSS, Servlet/JSP, ASP, PHP, … 30
  • 31. 01/01/2010 Suivi de Sessions avec HTTP (Session Tracking) Méthodes Le serveur génère un identificateur de session et associe un état (et une date limite de validité) à une session Le client renvoie l ’identificateur de session à chaque requête HTTP vers le serveur Didier Donsez, 1995-2010, HTTP Echange et Stockage de l’identificateur de session Input HIDDEN dans les formulaires Réécriture des URLs (EXTRA_PATH) Cookies (déactivable) Identificateur de session SSL (Secure Socket Layer) 31
  • 32. 01/01/2010 Suivi de session avec HTTP Une session s ’étend sur plusieurs requêtes documents, CGI, SSS, Servlet, ASP le serveur maintient un contexte de session et y associe un identifiant de session 3 solutions de suivi input HIDDEN contient l ’identifiant de la session la Ré-écriture d ’URL l ’identifiant dans chaque URL (dans les documents) Didier Donsez, 1995-2010, HTTP les Cookies information positionnée par le serveur sur le client la durée de vie du cookie dépasse la session puis envoyé par le client à chaque requête Implantation objet Session (ASP), classe HttpSession (JSP/Servlet) 32
  • 33. 01/01/2010 Suivi de Session une entrée HIDDEN par formulaire (i) Chaque réponse retournée par le serveur est un formulaire qui contient un identifiant caché dans une entrée HIDDEN Exemple • p a g e d e p ro p o s itio n Didier Donsez, 1995-2010, HTTP <FORM METHOD="POST" ACTION="/cgibin/command"> <INPUT TYPE="ckeckbox" NAME="art12387"> Chaussures ... </FORM> • ré p o n s e d e /c g i- b in /c o m m a n d <FORM METHOD="POST" ACTION="/cgi-bin/envoi"> <INPUT TYPE="hidden" NAME="TransID" VALUE="54109848932> Nom: <INPUT TYPE="text" NAME="nom"> Adresse: <INPUT TYPE="text" NAME="adresse"> N° de Carte de Credit: <INPUT TYPE="text" NAME="numcarte"> ... <INPUT TYPE="hidden" NAME="Language" VALUE="French> </FORM> 33
  • 34. 01/01/2010 Suivi de Session une entrée HIDDEN par formulaire (ii) Inconvénients dialogue uniquement par formulaire car pas de persistance de l'identifiant côté client Ambiguïté dans le cas des retours-arrière de l ’utilisateur annulation d ’une série d ’actions Didier Donsez, 1995-2010, HTTP ou série d ’action supplémentaire 34
  • 35. 01/01/2010 Suivi de Session la ré-écriture des URLs L ’identifiant de session est encodé dans les URLs des documents HTML retourné par le serveur. http://localhost:8080/servlet/cart?PROD_ID=383 devient http://localhost:8080/servlet/cart;jsessionid=To1128mC33718557521577075At?PROD_ID=383 Codage différent d’un serveur à l’autre. Didier Donsez, 1995-2010, HTTP field_sessionID = "JServSessionIdroot"; field_sessionID = ";jsessionid="; field_sessionID = "JIGSAW-SESSION-ID"; field_sessionID = ";$sessionid$"; //Apache/Jserv //Jakarta-Tomcat //Jigsaw web servers // WebSphere Limites URL générée par un script (=>programmation) ou parsing des documents HTML retournés mais disfonctionnement en présence de scripts JavaScript ou VBScript générant eux aussi des URL ! 35
  • 36. 01/01/2010 Suivi de Session les Cookies [Netscape puis RFC2109] chaîne décrivant l'état d'une session NAME=VALUE; expires=DATE; path=PATH_HEAD; / << /foo << /foobar ou /foo/bar.html domain=DOMAIN_TAIL; fr << mycomp.fr << sales.mycomp.fr stocké sur le client Limite Didier Donsez, 1995-2010, HTTP 300 cookies simultanées par client, 20 cookies par serveur ou domaine, 4Ko par cookie (limite la taille des VALUEs) communiqué dans les entêtes de requêtes (Cookie:) et dans les entêtes des réponses HTTP (SetCookie:) accessible par les scripts JavaScript dans une page HTML 36
  • 37. 01/01/2010 Positionnement des Cookies (i) GET / Web Browser Set-Cookie: VisitorID=12345; path=/; GET /book Cookie: VisitorID=12345; Set-Cookie: SID_book=88; path=/book; Didier Donsez, 1995-2010, HTTP GET /book/order Cookie: VisitorID=12345; Web browser’ cookies table Cookie:SID_book=88; VisitorID=12345; path=/; / /book /music Didier Donsez Web Server SID_book=88; path=/book; GET /music SID_music=999; path=/music; Cookie: VisitorID=12345; Set-Cookie: SID_music=999; path=/music; GET /music/buy Cookie: VisitorID=12345; Cookie: SID_music=999; 37
  • 38. 01/01/2010 Positionnement des Cookies (ii) Un autre jour ! Same Web Browser GET / Cookie: VisitorID=12345; GET /book Cookie: VisitorID=12345; Didier Donsez, 1995-2010, HTTP Set-Cookie: SID_book=101; path=/book; GET /book/logout Web browser’ cookies table Cookie: VisitorID=12345; Cookie:SID_book=101; VisitorID=12345; path=/; Set-Cookie: SID_book=0; path=/book; SID_book=101; path=/book; expires=0 GET / Cookie: VisitorID=12345; / /book /music Didier Donsez Web Server 38
  • 39. 01/01/2010 CC/PP (Composite Capabilities/Preference Profiles) Motivation Capacité du UA mobile et préférence usager envoyé au serveur en vue d’adapter la réponse Descriptions RDF Terminal Display size CPU Operating system Supported HTML Version Didier Donsez, 1995-2010, HTTP Usager Compatible WAP UAPROF Remarque: Devenu un nouveau WG « Device Independence » 44
  • 40. 01/01/2010 HTTPS (S comme Secure) Motivation Sécuriser (authentification, confidentialité) l’accès à un service Web SSL/TLS Phase 1 : Authentification du serveur et/ou du client par PKI Phase 2: Chiffrage avec une clé (secrète) symétrique de session Phase 2bis : Reprise après déconnexion HTTP over SSL (TLS) URL : https://host/document (Port TCP par défaut : 443) Didier Donsez, 1995-2010, HTTP HTTPS dans le JDK JSSE (javax.net.ssl.*) inclus dans J2SE 1.4 classe javax.net.HttpsURLConnection Voir cours JCE (http://wwwadele.imag.fr/users/Didier.Donsez/cours/jce.pdf) Serveurs Apache/SSL, iPlanet, MS IIS, OracleAS, IBM WebSphere … Carte hardware accélératrice (nFast de nCipher) 48
  • 41. 01/01/2010 HTTP-R (R comme « Reliable » Fiable) Under Construction En Proposé par IBM au W3C, mais toujours en coursConstruction ;-( Rappel HTTP est une couche de transport pour les messages SOAP dans la mise en œuvre les Web Services (B2B, EAI) Motivation Fiabiliser l’échange de messages entre le client et le service Web Échanger une et une seul fois même en cas d’interruption (déconnection, …) Didier Donsez, 1995-2010, HTTP Batch de plusieurs messages (requêtes et réponses) par commande Principe d’HTTPR Journaliser les messages (requêtes et réponses) côté client et côté serveur Notion de transaction Valider/Acquiter les échanges avec un protocole de validation Ajout de nouvelles commandes 49
  • 42. 01/01/2010 Nouvelles « commandes » de HTTPR Under Construction Ces commandes sont portées par la commande HTTP POST En Construction PUSH Le client envoie un ou plusieurs messages qui seront journalisées par le serveur La séquence de messages est associée à un identifiant de transaction Peut contenir des acquittements à des commandes précédentes PULL Demande à recevoir des messages en attente coté serveur Peut contenir des acquittements à des commandes précédentes EXCHANGE Didier Donsez, 1995-2010, HTTP Combine PUSH et PULL RESOLVE Permet de déterminer les messages recus et journalisés par le serveur REPORT Permet de rapporter au serveur les messages recus et journalisés par le client GET RESPONDER INFO Information pour le serveur sur le niveau de protocole supporté par le client 50
  • 43. 01/01/2010 HTTPU & HTTPMU HTTPU (HTTP Unicast over UDP) HTTPMU (HTTP Multicast over UDP) Under Construction En Construction Didier Donsez, 1995-2010, HTTP Utilisé par UPnP http ://www.upnp.org/about/default.asp pour le protocole de découverte de service (SSDS (Simple Service Discovery Protocol)) 52
  • 44. 01/01/2010 XML-RPC vs SOAP vs REST Motivations Program-to-Program B2B, AJAX, … XML-RPC HTTP POST Simple encoding schema Didier Donsez, 1995-2010, HTTP SOAP operation-centric WSDL REST more URL-centric 53
  • 45. 01/01/2010 REST (Representational State Transfer) “Amazon has both SOAP and REST interfaces to their web services, and 85% of their usage is of the REST interface.” Motivation Didier Donsez, 1995-2010, HTTP L’encodage d’une requete SOAP est complexe pour le néophyte Utilisation du passage de paramètre de HTTP GET Roy Thomas Fielding. Architectural styles and the design of network-based software architectures. PhD thesis, University of California, Irvine, 2000. http://www.ics.uci.edu/~fielding/pubs/dissertation/top.htm 54
  • 46. Les clients (UA) et les serveurs HTTP Didier DONSEZ Université Joseph Fourier (Grenoble 1) PolyTech’Grenoble – LIG/ADELE Didier.Donsez@imag.fr Didier.Donsez@ieee.org
  • 47. 01/01/2010 Les Client (User-Agents) HTTP Butineur ou Arpenteur ou Brouteur Web (browser Web) Récupère un document puis « visualise » ce document Didier Donsez, 1995-2010, HTTP Sur station le tout premier : NCSA Mosaic Netscape Communicator/Mozilla/Firefox MS Internet Explorer Opera Konqueror Javasoft HotJava … Lynx (pour VT, Minitel 24x80) AvantGo, MS Pocket Explorer, … (pour PDA) 56
  • 48. 01/01/2010 Autres Client (User-Agents) HTTP HTTPClient http://hc.apache.org/ components for client-side authentication, HTTP state management, connection management, and an HTTP/1.1. compliant HTTP agent implementation based on those components Curl http://curl.haxx.se/docs/manpage.html Didier Donsez, 1995-2010, HTTP command line tool for transferring files with URL syntax, supporting FTP, FTPS, HTTP, HTTPS, SCP, SFTP, TFTP, TELNET, DICT, LDAP, LDAPS and FILE. curl supports SSL certificates, HTTP POST, HTTP PUT, FTP uploading, HTTP form based upload, proxies, cookies, user+password authentication (Basic, Digest, NTLM, Negotiate, kerberos...), file transfer resume, proxy tunneling and a busload of other useful tricks. 57
  • 49. 01/01/2010 Palmarès d ’utilisation des butineurs MS IE est en tête 12/2002 Didier Donsez, 1995-2010, HTTP Microsoft IE 6.0 Microsoft IE 5.5 Microsoft IE 5.0 Netscape Navigator 4.0 Mozilla 1 Microsoft IE 4.0 Opera 6.0 The winner is ... Microsoft IE Netscape Navigator Mozilla 07/2003 57.6% 18.3% 16.9% 1.1% 1.1% 0.9% 0.8% 66.3% 14.5% 12.7% 0.6% 1.6% 0.8% 0.6% 95.0% 3.0% 1.1% 95.4% 2.5% 1.6% 58
  • 50. 01/01/2010 Les User-Agents HTTP Mais aussi sur Console de Jeux, PDA, iTV, Téléphone Cellulaire WinCE Pocket Explorer, AvantGo ... Navigation Online / Offline Didier Donsez, 1995-2010, HTTP Ladtop, PDA, … Récupération en push dans un cache Puis consultation des documents dans le cache 59
  • 51. 01/01/2010 Les Serveurs du Marché Offre logiciel très large NSCA HTTPD, l’ancêtre Apache & Jakarta/Tomcat (19 millions de serveurs (09/2001)) iPlanet et Netscape Entreprise Server Microsoft Internet Information Server (8.9 millions de serveurs (09/2001)) W3C Jigsaw Sun JavaServer Oracle Web Server, abandonné par Oracle au profit d’Apache IBM Web Sphere, intègre Apache Resin, Jetty, Zeus… Didier Donsez, 1995-2010, HTTP Offre matériel Server Appliances : Qube, … Composants pour des serveurs embarqués Fonctionnalités supplémentaires gestion des sessions, des transactions, … accès aux serveurs d ’applications, ... A regarder régulièrement http://news.netcraft.com/archives/web_server_survey.html 60
  • 52. 01/01/2010 Les Serveurs du Marché Nombre de site Didier Donsez, 1995-2010, HTTP http://news.netcraft.com/archives/web_server_survey.html 61
  • 53. 01/01/2010 Les Serveurs du Marché Market share Didier Donsez, 1995-2010, HTTP http://news.netcraft.com/archives/web_server_survey.html 62
  • 54. 01/01/2010 Rôle d'un serveur HTTP Transformation de l'URL en fichier ou en script Vérification d'identité Le client est-il qui il prétend être ? Vérification d'accès Le client est-il autorisé à effectuer cette requête ? ACL, … Constitution de l ’entête de la réponse Type MIME des données Didier Donsez, 1995-2010, HTTP mime.types fichier de correspondance extension vers type MIME Taille des données, Langage, ... Envoi de la réponse au client éventuellement transformé à la volée Mise à jour des journaux d ’audit (log) access_log, error_log, ... 63
  • 55. 01/01/2010 L ’authentification dans HTTP Indiqué dans les ACL Mode d ’authentification BASIC (RFC 2617) nom d ’utilisateur et mot de passe échangé en clair (base64) ! base des mots de passe dans un fichier htpasswd utilitaires de gestion du fichier DIGEST (RFC 2617) Didier Donsez, 1995-2010, HTTP sécurisation de BASIC hachage sécurisé MD5 du (nom,password,URI, méthode,nombre aléatoire fourni par le serveur) SSL/TLS Secure Socket Layer (TLS : Transport Layer Security) authentification avec CA du serveur (2.0) et du client (3.0) confidentialité avec DES puis dialogue HTTP sur la connexion SSL Remarque : utilisation des cartes PKI pour l’identification du client 64
  • 56. 01/01/2010 L ’authentification applicative Motivations interface de login authentification plus forte (SSL) Base d’identité Fichier htpasswd, BD, Annuaire LDAP, … (voir mod_auth_xxx de Apache) L’application gère l ’authentification de l ’usager Didier Donsez, 1995-2010, HTTP formulaire d ’accueil HTML (nom, password) attention le mot de passe circule en « clair » Utilisez une fonction JavaScript de hachage (MD5,SHA1) du mot de passe avec un nombre aléatoire pour éviter le « replay » gestion des tables d ’usager une session est ensuite ouverte associé à un usager authentifié (ou non : par exemple rejet à bout de 3 tentatives) Remarque TomCat peut de préciser les documents de login et d’errreur pour une arborescence de documents/servlets/JSP 65
  • 57. 01/01/2010 Contrôle d ’Accès dans HTTP ACL (Access Control List) spécifie les autorisations (ALLOW) ou les interdictions (DENY) d ’accès à une arborescence virtuelle du serveur en fonction Didier Donsez, 1995-2010, HTTP de l ’authentification de la localisation du client sous domaine DNS réseau ou adresse IP ACF (Access Control File) fichier regroupant les ACL global : access.conf dans Apache par arborescence : .htaccess combinaison des ALLOW et des DENY 66
  • 58. 01/01/2010 Audit des Requêtes Journaux des requêtes les accès (access.log, refferee.log), et les erreurs (error.log), … sont journalisés Exploitation des Journaux erreur dans les liens, … clientèle, analyse d ’activité, … Didier Donsez, 1995-2010, HTTP Reporting (Présentation Synthétique) Pour Apache AccessWatch, Wusage,Analog, wwwstat IIS, NS intégré et visualisé par un script Généraux Net Analysis (Net Genesis), Enterprise Suite (Web Trends) 67
  • 59. 01/01/2010 Apache (www.apache.org) A patch of NCSA HTTPD serveur le plus répandu (62% des serveurs au 04/2001, 18 Millions de serveur) gratuit, issu du serveur NCSA HTTPD très nombreuses plates-formes Unix et Windows NT extensible par des modules tiers Nombreux Modules Tiers Didier Donsez, 1995-2010, HTTP possibilité d’étendre Apache avec des modules externes (http://www.zyzzzyva.com/server/module_registry) mod_auth_cookies_file, mod_auth_cookies_msql, mod_cgi_sugid, mod_perl, mod_perl_fast, mod_auth_kerb, mod_auth_dbi, mod_rewrite, mod_jserv (servlet), mod_java (CGI écrit en Java), php3 nombreux sous-projets autour de Java (Jakarta) et XML (Xerces, Xalan, XSP, Cocoon, …) 68
  • 60. 01/01/2010 Jakarta Tomcat (jakarta.apache.org) Moteur (engine) de Servlet/JSP Catalina : Container JavaEE de Servlet Jasper : Container JavaEE de JSP Connecteurs Admin (8007) Démarrer/relancer/arrêter Tomcat HTTP 1.1 peut servir directement des clients HTTP Didier Donsez, 1995-2010, HTTP HTTPS peut servir directement des clients HTTP sur SSL/TLS Il est préférable d’utiliser Apache/SSL + AJP12, AJP13, WARP AJP12, AJP13, WARP Avec des serveurs HTTP supportant WARP Fonctionnement possible en « embedded » cad dans une machine virtuelle avec d’autres services (containers EJB, …) 70
  • 61. 01/01/2010 Apache/JServ et Jakarta Tomcat (java.apache.org) mod_Jserv / mod_jk : module d’extension Apache Démarre une JVM et invoque des servlets TomCat : serveur écrit en Java A utiliser comme Servlet et JSP engine Configuration possible Apache Server mod_xxx Didier Donsez, 1995-2010, HTTP (.dll, .so) Client HTML Client HTML Client HTML HTML HTTP/HTTPS HTML mod_jserv/jk AJP (.dll, .so) (port 8007) HTML HTTP/HTTPS HTML HTTP/HTTPS A éviter en production (perf, sécurité) Pages Statiques Jakarta TomCat Server servlet/jsp servlet/jsp FileServlet Pages Statiques 71
  • 62. 01/01/2010 JavaServer Serveur HTTPD de SUN anciennement « Jeeves », écrit en Java Abandonné au profit de Tomcat (jakarta.apache.com) qui est devenu l’implémentation de références pour les Servlets, JSP, JSTL Servlets Didier Donsez, 1995-2010, HTTP Scripts serveur écrit en Java Servlets de Base : FileServlet, CGIServlet, … Remarque le bytecode d ’une servlet peut être téléchargé et executé par la JVM du Serveur (dans un espace protégé ou non) JigSaw du W3C fonctionne suivant le même principe 72
  • 63. 01/01/2010 MS Internet Information Server Plate-forme Systèmes Serveur de Windows 8.9 millions de serveurs (09/2001) Scripts ASP, ASP .NET Interface native ISAPI (C, C++, …) Didier Donsez, 1995-2010, HTTP Remarque PWS : Personal Web Server (pour les systèmes WorkStation) Maintenant intégré à MS .NET (Web Services, …) Cassini (ASP .NET Web Server pour le développement) 73
  • 64. 01/01/2010 Autour d ’HTTP Proxy seul point de passage entre le réseau d ’entreprise et l extérieur sécurité, firewall accès à des protocoles non implémentés par les clients Web : WAIS, … Cache soulager les accès externes (moins de bande passante) Miroir réplication d ’une base documentaire améliorer le temps de réponse, soulager le réseau Robot Didier Donsez, 1995-2010, HTTP récupération online/offline d ’une arborescence de documents constitution d ’un miroir local Mise à jour de sites copie publique / copies de travail Portail Point d’accès centralisant à un ensemble de sources Web Embedded Web Server Serveur HTTP pour informatique enfouie et embarquée 81
  • 65. 01/01/2010 Proxy Fonctions seul point de passage entre le réseau d ’entreprise et l ’extérieur firewall, contrôler le profil d'utilisation, portail vers des ressources externes contrôlées (banques de données, …) accès à des protocoles non implémentés par les clients Web Didier Donsez, 1995-2010, HTTP WAIS, LDAP… Passerelle réseau de niveau applicatif Navigateur Web HTTP + HTML Proxy HTTP+HTML / WAIS Serveur WAIS Z35.50 Couches OSI 1-6 Couches OSI 1-6 Couches OSI 1-6 82
  • 66. 01/01/2010 Fonctionnement du Proxy/Cache GET /fichier HTTPD Client port 80 machX GET /ficX Didier Donsez, 1995-2010, HTTP GET http://machX/ficX Client fichier Proxy GET http://machY/ficY Entreprise ficX machX port 8080 cache machP HTTPD HTTPD GET /ficY ficY machY Internet 83
  • 67. 01/01/2010 Cache Web But d ’un cache Réseau Usager Améliorer les performances du browser en utilisant les documents présents dans le cache local ISP Soulager le réseau fédérateur en cachant les documents demandés par les usagers du sous-réseau Provider Web Soulager les serveurs applicatifs Didier Donsez, 1995-2010, HTTP Documents Textes (HTML, XML, ...) et Images fixes Flux Audio et Video têtes de réseau cable pour la Buffered-VOD Serveurs Il fonctionne en mode Proxy Squid, Harvest, Apache, MicroSoft, Sun, iPlanet, OracleAS WebCache, WebSphere ... 84
  • 68. 01/01/2010 Cache Web ii Politique de remplacement de cache Web Least Recently Used (LRU) très populaire conserve la date du dernier accès Least Frequently Used (LFU) comptage du nombre de références éviction des documents les moins référencés Didier Donsez, 1995-2010, HTTP LFU-Aging LFU + prise en compte de la durée de la présence dans le cache Greedy Dual-Size (GDS) prise en compte la taille GDS-Frequency (GDSF) GDS + prise en compte du nombre de référence 85
  • 69. 01/01/2010 Cache Web iii Cache de Caches Hiérarchie multi-niveaux de caches exemple : RENATER cache Client -> cache Sous Réseau -> cache Backbone -> ... équilibrage dynamique entre plusieurs caches de même niveau ICP : Inter Cache Protocol Didier Donsez, 1995-2010, HTTP mise à jour, invalidation, redirections de requête 86
  • 70. 01/01/2010 Gestion du Cache Le document est il dans le cache ? Non Non Oui Le document est il périmé ? date d ’expiration dépassée Didier Donsez, 1995-2010, HTTP Oui Non : le cache arrête la connexion avec le serveur et retourne au client le document caché le cache démarre la récupération Le document a t’il été modifié ? date de modification identique le cache se connexe au serveur pour récupérer l ’entête (méthode HEAD) Oui Le serveur continue la récupération même si le client interrompt la connexion Le document est récupéré, mis dans le cache, retourné au client 87
  • 71. 01/01/2010 Content Delivery Network (CDN) Web cache aux points de présence du(des) FAI entre le fournisseur et ses clients Documents cachés Statique, Stream, Fragments de compositions dynamiques (ESI) Avantages Latence réduite, décharge du serveur fournisseur (allocation de serveurs à la demande, …), décharge du réseau central FAIs Didier Donsez, 1995-2010, HTTP Inconvénients Usage de DNS dynamique dissociée pour cachable et non cachable Réécriture dynamique d’URL Acteurs Akamaï (+Digital Island) ~80% du marché plus de 20000 (surogate) serveurs low-cost sur 63 pays Adero, Mirror Image, Inktomi, … 88
  • 72. 01/01/2010 Content Delivery Network (CDN) le Edge Computing navigateurs web pull Internet serveurs applicatifs Didier Donsez, 1995-2010, HTTP requêtes par millions navigateurs web centaines de serveurs frontières pull requêtes par millions Dynamic Caching and Content Assembly Internet fragments HTML à cacher requêtes par millions serveurs applicatif requêtes par milliers serveurs bases de données requêtes par millions serveur bases de données requêtes par milliers 89
  • 73. 01/01/2010 Miroir But Créer une copie miroir d ’un site (d ’une partie de site) accélère l ’accès au document diminue la contention d ’accès au site diminue le trafic global sur Internet Mise à jour du miroir Didier Donsez, 1995-2010, HTTP déclenchement automatique, manuel, push incrémentale / non 91
  • 74. 01/01/2010 iCAP (i) Internet Content Adaptation Protocol Motivations permettre à un proxy (HTTP, FTP, NNTP, SMTP) d’intercepter les messages et de les faire traiter/modifier « à la volée » par d’autres services Didier Donsez, 1995-2010, HTTP Exemple d’utilisation : Détection de virus, Insertion de bannière publicitaire, Reroutage, Détection de langage, Traduction multilingue, Conversion de format (image, …),Contrôle parental … 92
  • 75. 01/01/2010 iCAP (ii) Internet Content Adaptation Protocol Architecture Client HTTP Didier Donsez, 1995-2010, HTTP Protocole Proxy HTTP (Client iCAP) Serveur iCAP Antivirus Serveur HTTP Serveur iCAP Traducteur RFC IETF Couche Transport : HTTP Méthodes : RESPMOD, REQMOD, OPTIONS Encapsulation du message (HTTP, …) URL : icap://host:port/service (port par défaut : 1344) Implémentation : iPlanet, … 93
  • 77. 01/01/2010 Robot (Aspirateur de Site, Glaneur, ...) Récupération d ’une arborescence de documents à partir d ’une URL « racine » Règles de récupération par rapport aux extensions (que les textes) profondeur du suivi de URL et limite de la récupération Déclenchement programmé heures creuses (débit et $) Produits nombreux freewares/sharewares Didier Donsez, 1995-2010, HTTP webcopy, wget, w3mir, Jobo ... Fonction miroir intégrée dans les logiciels auteurs MS FrontPage, Goto MemoWeb, ... Remarque permet de créer facilement un miroir utile à la navigation offline 95
  • 78. 01/01/2010 Robot Directive pour les robots Faciliter le travail des robots des moteurs d’indexation META HTML <META NAME='revisit-after' CONTENT='15 days'> <META NAME='robots' CONTENT='index,follow'> <META NAME="keywords" CONTENT="Cours HTTP, Robot, WebDAV "> Fichier /robots.txt (http://www.robotstxt.org/wc/norobots.html) Didier Donsez, 1995-2010, HTTP Interdit aux robots certains répertoires ou documents Exemple # interdit cyberworld/map/ a tout robot User-agent: * Disallow: /cyberworld/map/ # sauf à Cybermapper qui peut tout visiter User-agent: cybermapper Disallow: 96
  • 79. 01/01/2010 Mise à jour des sites Actuellement, chaque auteur travaille sur une copie locale et remplace la copie publiée sur le Web par celle-çi régulièrement Remplacement des pages par FTP problème de gestion des versions multiples lors d ’un travail de groupe par un script HTTP serveur propriétaire Didier Donsez, 1995-2010, HTTP et information propriétaire associée utilisé par MS FrontPage, NetObjects Team Fusion, Macromedia DreamWeaver, … mais pas d ’interopérabilité WebDAV [RFC 2518] Web Distributed Authoring and Versioning Protocol le dernier effort de standardisation 97
  • 80. 01/01/2010 WebDAV (1/3) Web Distributed Authoring and Versioning Protocol Extension de HTTP pour la mise à jour de site (RFC 2518) www.webdav.org, www.ics.uci.edu/pub/ietf/webdav Notions Propertie (propriété) Didier Donsez, 1995-2010, HTTP décrit un document (auteur, taille, date de dernière modification, ...) au format XML/RDF Collection Locking (verrouillage) verrou partagé (shared) / verrou exclusif (exclusive) Namespace (espace de nommage) groupement logique de ressource pour la gestion (verrouillage, contrôle d ’accès, ...) 98
  • 81. 01/01/2010 WebDAV (2/3) Web Distributed Authoring and Versioning Protocol Ajout de nouvelles commandes HTTP PROPFIND retourne les propriétés PROPPATCH modifie les propriétés MKCOL crée une nouvelle collection Didier Donsez, 1995-2010, HTTP COPY & MOVE copie ou déplace une ressource au sein d ’un espace de nommage LOCK & UNLOCK verrouille et déverouille un ressource 99
  • 82. 01/01/2010 WebDAV (3/3) Web Distributed Authoring and Versioning Protocol des Serveurs WebDAV MS IIS5 CyberTeams ’ Web Site Director mod_dav pour Apache (www.webdav.org/mod_dav) Support dans Tomcat org.apache.catalina.servlets.WebdavServlet Didier Donsez, 1995-2010, HTTP des Clients WebDAV MS Office 2000 et Explorer 5 Adobe GoLive) Cadaver 0.15 DAV Explorer 0.60 and 0.70 Jakarta Slide 1.0 WebDAV client library SkunkDAV 1.0 A voir http://www.webdav.org 100
  • 83. 01/01/2010 WebDAV/DeltaV (RFC 3253) Extension de WebDAV pour le support des révisions Auto-versionning Didier Donsez, 1995-2010, HTTP Possibilité de révision avec des clients WebDAV non DeltaV Utilisé par SubVersion mod_dav_svn (http/https) 101
  • 84. 01/01/2010 Portail (i) Objectif Point d’accès centralisant un ensemble de sources d’information Web Intra-entreprise (Enterprise Information Portal ou Web Based Groupware) Contenu : Favorite links, Agenda, Mail, Incident, Challenge Force de Vente … Grand public Contenu : Info Bourse, Enchère, Météo, Programme TV et Ciné, News Headline, Courrier (HTML), SMS … B2B pour des agrégateurs de Web Services Fonctionnalités Usagers Anomymes/Authentifiés Didier Donsez, 1995-2010, HTTP Sécurisation (SSL, X509, cookie …) Personnalisé en fonction de l’usager, de son role, de son emplacement géographique, … Personnalisable(Self-Service) Composition dynamique (utilisation d’assistants, …) Multi-Accès (PC, Téléphone Cellulaire, PDA, …) Outils JSR 168, Oracle Portal, NetPortal, WebPortal, iPlanet Portal, Apache Portals, … 102
  • 85. 01/01/2010 Portail (ii) Présentation (GUI) 1 page d’accueil composite -> N onglets -> M zones (div, layer, frame, card, …) iconifiable, agrandissement/réduction, ajout/retrait, … Développement de Portlet Notion de PortLet : représente une source de données à placer dans la page Portal Server Identification LDAP, … Annuaire, … HTML/CSS Personnalisation XML/XSL PortLet Didier Donsez, 1995-2010, HTTP WML Client VoiceML HTTP WAP Portlet Container PortLet PortLet PortLet Nouveau métier : provider de PortLet HTML HTTP XML HTTP XML HTTP SOAP HTTP Internal Web Provider Internal Web Provider External (Meteo) Web Provider External (Bourse) Web Provider 103
  • 86. 01/01/2010 Portail (iii) Exemple de GUI HTML (My Yahoo) Identification Portlet Portfolio Portlet Mail Didier Donsez, 1995-2010, HTTP Portlet News Portlet Weather 104
  • 87. 01/01/2010 Portails Apache http://portals.apache.org/ JetSpeed 1 et 2 Servlet de portail Web et WAP Description PSML (Portal Structure Markup Language) par utilisateur Description des portlets et de leur contenu, de leur mise en page Pluto Didier Donsez, 1995-2010, HTTP Reference Implementation of the Java Portlet Specification (JSR 168) Pluto is a portlet container. WSRP4J Reference Implementation of the Oasis (Web Services for Remote Portlets) Specification. WSRP standard simplifies integration of remote applications/content into portals so that portal administrators can pick from a rich choice of services and integrate it in their portal without programming effort. 105
  • 88. 01/01/2010 Cartographie du Web Grouper les sites en « régions » en fonction de leur relation sémantique, des références d ’URL Représentation de la carte Didier Donsez, 1995-2010, HTTP hyperbolique, cible 2D, … Outils et sites www.semio.com, www.acetic.fr, www.umap.com, ... 106
  • 89. 01/01/2010 Mesures et Rapports d ’audience (MédiaMétrie) Pourquoi faire : suivi et analyse de l ’activité du site webmaster : dimensionner le système (période de charge) commercial : pister le client dans sa navigation investisseur : le rassurer avant l ’introduction en Bourse ;-) publicitaire : fixer le prix des bandeaux publicitaires 2 fonctions Didier Donsez, 1995-2010, HTTP Récupération des clics à partir des journaux du serveur HTTP (access.log) inconvenients : les journaux grossissent très vite scripts JavaScript/applet embarqués dans les pages Images masquées Analyse Datawarehouse, DataMining Rapport, OLAP, Segmentation online (Profilage online) 107
  • 90. 01/01/2010 Mesures et Rapports d ’audience (MédiaMétrie) Acteurs Insight (Accrue), WebHound (SAS Institute) http://awstats.sourceforge.net/ Didier Donsez, 1995-2010, HTTP A lire DEVANSHU DHYANI, WEE KEONG NG, SOURAV S. BHOWMICK, « A Survey of Web Metrics », ACM Computing Surveys, Vol. 34, No. 4, December 2002. 108
  • 91. 01/01/2010 Mesures et Rapports d ’audience (MédiaMétrie) Externalisation des rapports d’audiance Pourquoi faire : rapport de l’activité du site investisseur : le rassurer avant l ’introduction en Bourse ;-) publicitaire : fixer le prix des bandeaux publicitaires Didier Donsez, 1995-2010, HTTP Méthodes société tierce « indépendante » proposant des rapports « normalisés » (Exemple : www.estat.com, ...). chaque page à tracer contient une image transparente de 1x1 pixel qui est chargée depuis la société tierce. La société tierce comptabilise les chargements. <IMG SRC="http://www.tierce.com?idcust=190874+doc=/product/index.htm"> 109
  • 92. 01/01/2010 Rapports d ’audience Exemple Didier Donsez, 1995-2010, HTTP Rapport d ’audience 110
  • 93. 01/01/2010 Rapports d ’audience Exemple Didier Donsez, 1995-2010, HTTP Rapport d ’audience Temps réel de www.geoloc.com 111
  • 94. 01/01/2010 Service pour le e-Commerce Géo-localisation IP Pays d’origine d’une adresse/domaine IP Ex: http://www.maxmind.com/ Validation des cartes de crédit/bancaires Pays d’origine fortement sujet à la fraude Didier Donsez, 1995-2010, HTTP Ukraine, Indonesia, Yugoslavia, Lithuania, Egypt, Romania, Bulgaria Turkey, Russia, Pakistan, Malaysia, Israel, … Services externes via des Web-Services 112
  • 95. 01/01/2010 La Personnalisation Motivations Les usagers d ’un site ont des goûts et des besoins différents La personnalisation tente d ’offrir à l ’usager une interface correspondant le plus possible à ses goûts et ses besoins Solutions Analyse (E-Analytics) Didier Donsez, 1995-2010, HTTP Analyse des navigations précédentes de l ’usager Net Perceptions, Accrue Software, NetGenesis Corp Personnalisation sur règles (Rules-based Personalization) Création des pages personnalisées à la volée en fonction de régles BroadVision, Vignette Corp. Filtrage collaboratif (Collaborative Filtering) similarité entre utilisateurs : comportement de groupes Net Perceptions, Macromedia, Be Free 113
  • 96. 01/01/2010 Qualité Motivation Vérification de la Conformité (Correctness) aux spécifications (donné par le client) Non régression Outils Didier Donsez, 1995-2010, HTTP Test unitaire et rapport : JUnit+Cactus 114
  • 97. 01/01/2010 Test de performance / charge Motivation Vérification du niveau de charge supporté avant la mise en production Benchmark TPC-W (Bookstore online) http://www.tpc.org voir Cours Benchmarks Didier Donsez, 1995-2010, HTTP BD WebMark : orienté requête HTTP/GET sur des documents statiques SPECWeb : http://www.spec.org/osg/web99/ Rubis (eBay auction) http://rubis.objectweb.org Rubos (PHP News SlashDot) CSIRO (Stock online) Mauro Andreolini, Valeria Cardellini, Michele Colajanni: Benchmarking Models and Tools for Distributed Web-Server Systems. Performance 2002: 208-235 Analyse et diagnostique de la charge Détecter quel composant (HTTPD, EJB, MT, SGBD, Mailhost, MQ 115 …) en créant l’embouteuillage (bottleneck)
  • 98. 01/01/2010 Test de performance / charge (ii) Injecteur de charge 1à N clients en parallèle qui émulent M WebSurfers sur le site Script définissant la navigation (automate, temporisation, …) Monitoring Monitoring Didier Donsez, 1995-2010, HTTP Tested system Simulate clients connections Cluster of clients Frontend Application Server Backend 116
  • 99. 01/01/2010 Test de performance / charge (iii) Outils Apache Benchmark Tool (ab), Siege, Apache JMeter, ObjectWeb CLIF, IBM/Rational SiteLoad, LoadRunner, TestMaker, Grinder (http://grinder.sourceforge.net/), … Remarque Didier Donsez, 1995-2010, HTTP Mêmes outils pour les attaques DoS (Deny-Of-Service) et Distributed DoS 117
  • 100. 01/01/2010 Test de performance / charge (iv) Exemple: Apache JMeter Didier Donsez, 1995-2010, HTTP Screenshot to add 118
  • 101. 01/01/2010 Balancing) Disponibilité (Avaibility) Motivations Performance Améliorer/garantir les temps de réponse Exigé par des portails (vers votre service) comme Yahoo QoS pondérée pour différentes classes d’usagers (gold, silver, …) Évolution incrémentale de la ferme (parc) de serveurs Didier Donsez, 1995-2010, HTTP Disponibilité Tolérance aux pannes Différents niveaux de disponibilité fonctionnement dégradé en cas de panne Le serveur Europe reçoit les requêtes des clients français Failover : Interruption de service Basculement d’une session vers un autre serveur sans interruption de service Voir: V. Cardellini, M. Colajanni, P.S.Yu, Dynamic Load Balancing on WebServer Systems, IEEE Internet Computing, May-June 1999, pp28-39 Swaminathan Sivasubramanian, Michal Szymaniak, Guillaume Pierre, Maarten van Steen, Replication for web hosting systems. ACM Computing Surveys, Vol 36, N° 2004 ,pp 291-334 3, 119
  • 102. 01/01/2010 Répartition de Charge (Load Balancing) Architecture Un serveur de répartition de charge Une ferme de serveurs Web Serveur WWW Gold France Didier Donsez, 1995-2010, HTTP 100 Client WWW Gold France 10000 Client WWW France 10000 Client WWW Allemagne Serveur de Répartition de Charge Serveur WWW France Serveur WWW Europe Information sur la charge et les pannes 120
  • 103. 01/01/2010 Disponibilité (Avaibility) Cas d’une panne Les clients français sont servis par le serveur Europe La panne peut être détectée par des pings réguliers ! Serveur WWW Gold France Didier Donsez, 1995-2010, HTTP Client WWW Gold France Client WWW France Client WWW Allemagne Serveur de Répartition de Charge Serveur WWW France Serveur WWW Europe Information sur la charge et les pannes 121
  • 104. 01/01/2010 FailOver Ininterruption de service Reprise de la session par un autre nœud du cluster Solutions Réplication de données de HttpSession entre les nœuds Technologies Données de session persistantes (BD, Fichiers) Didier Donsez, 1995-2010, HTTP IO traffic bottleneck In memory Replication (Communication de Groupes) Voir article Clustering, theServerSide, April 2002 JavaGroup (reliable and synchronous multicast) 122
  • 105. 01/01/2010 Serveur de Répartition de Charge Fonction répartir les requêtes entre les serveurs Web (entre les serveurs applicatifs) Politiques de répartition Didier Donsez, 1995-2010, HTTP donneur de cartes ([weighted Round Robin]) aléatoire vers les serveurs les moins chargés topologique Optimiser la bande passante de l’infrastructure réseau L’entreprise dispose de serveurs répartis sur plusieurs backbones du Web en fonction de la classe d’usagers Offrir différentes QoS (temps de réponse, …) en fonction des sessions en cours Une session démarrée sur un serveur doit continuer sur ce serveur SSL, Cookies de session pour Http, Stream du RealServer, … Fournisseurs 123 Alteon WebSystems, F5, Foundry Networks, Radware, CISCO, …
  • 106. 01/01/2010 Niveaux de la Répartition de Charge par le Serveur de Répartition (i) Niveau 3 – IP Répartition par le DNS La résolution DNS n’est pas une constante (Round-Robin DNS, GeoDNS) une adresse DNS correspond une liste d’adresses IP à tester nslookup plusieurs fois de suite sur www.sun.com Didier Donsez, 1995-2010, HTTP Future RFP VRRP (Virtual Router Redondancy Protocol) Grappe de routeurs derrière un routeur virtuel Adresse MAC sur LAN Adresse IP sur WAN Niveau 4 (TCP-Router) Session SSL 124
  • 107. 01/01/2010 Niveaux de la Répartition de Charge par le Serveur de Répartition (ii) Niveau 7 – Applicatif Protocole HTTP Détection du Cookie de la classe d’usager dans une requête HTTP Détection du Cookie de l’identifiant de session dans une requête HTTP Protocoles FTP, SMTP, … Flux Audio/Vidéo, … Rappel : Redirection (301) de la requête HTTP Didier Donsez, 1995-2010, HTTP Aisement intégrable à une webapp JavaEE grâce au javax.servlet.Filter En savoir plus Valeria Cardellini, Michele Colajanni, Philip S. Yu: Dynamic Load Balancing on Web-Server Systems. IEEE Internet Computing 3 (3): 28-39 (1999) Valeria Cardellini, Emiliano Casalicchio, Michele Colajanni, Philip S. Yu: The state of the art in locally distributed Web-server systems. ACM Comput. Surv. 34 (2): 263311 (2002) 125
  • 108. 01/01/2010 Performance grâce aux caches 2 types de page Dynamique Le contenu varie à chaque requête Le contenu peut rester constante pour un client au cours de sa session Statique Le contenu ne varie pas jusqu’à la prochaine modification Exemple : Mise à jour des nouvelles du jour tous les matins à 7H00 GMT Didier Donsez, 1995-2010, HTTP Les caches dans les proxys et dans les navigateurs utilise la date d’expiration du document Conseil Pour éviter que le navigateur recharge le document inutile (ce qui charge le serveur), configurez les dates d’expiration des documents sur le serveur Web et dans les entêtes des réponses des scripts. 126
  • 109. 01/01/2010 Les Moteurs d ’Indexation (1/2) L ’utilisateur utilise deux modes de parcours d ’un site Le suivi de liens La recherche Full-Text par combinaison de mots-clé et de concepts (antoine NEAR(15) cléopatre) AND NOT césar Recherche Plein Texte (Full-Text) pré-indexation du corpus documentaire Remarque : le corpus peut provenir du Web (i.e. Portails) Problème : les documents générés à la volée Didier Donsez, 1995-2010, HTTP le script /cgi-bin/search interroge l ’index généré en Offline 1- GET /cgi/search?q=donsez 2- Liste de ref Client HTML 3- GET ref 4- ref Online Serveur HTTPD Copie Publiée Index Indexeur FullText Index en Mise à Jour Génération Offline 127
  • 110. 01/01/2010 Les Moteurs d ’Indexation (2/2) Indexeurs (gratuit ou payant) FreeWAIS, Glimpse, ht://Dig, Harvest, AltaVista, Verity Search, AIRS, Basis, Oracle Context, Doris-Floras, RetrievalWare, Virage, QBIC, Google, Jakarta lucene, … Caractéristiques Indexation incrémentale vs totale l’ajout d ’un document au corpus ne nécessite pas de reconstruire l ’index Types de document indexés Didier Donsez, 1995-2010, HTTP Texte, Texte structuré Multimédia : Images, Sons, Vidéo (MPEG7), Monde 3D … Formats de document analysés HTML, XML, PDF, Word/RTF, GIF, JPEG, MPEG, ... Bibliographie C. Leloup, “Moteurs d'Indexation et de Recherche”, Ed. Eyrolles, 1998, ISBN 2-212-08976-7 Remarque: Google Desktop Search indexation des volumes locaux, plugins tiers additionnables 128
  • 111. 01/01/2010 Les Antéserveurs (i) Documents générés à la volée nécessite de bonne performance du serveur HTTP et du serveur BD Coût des requêtes SQL auprès du serveur BD Didier Donsez, 1995-2010, HTTP 1- requête HTTP Client HTML 4- réponse HTML 2-requête SQL Serveur Serveur HTTPD Applicatif 3-Table SQL SGBD OLTP BD Online 129
  • 112. 01/01/2010 Les Antéserveurs (ii) Cache des résultats (page HTML) des requêtes SQL fréquemment posées Terme: Remarque : importance des informations de cache Edge Computing dans les entêtes de réponse HTTP Didier Donsez, 1995-2010, HTTP Client HTML 1- requête HTTP 2 Reverse 6- réponse HTML Proxy(s) / 7- même Edge requête HTTP Servers Autre Client 9- réponse HTML HTML 8 5 6 Cache Online Serveur HTTPD 3- Requête SQL SGBD + Serveur 4- Table SQL Applicatif Invalidation d’une partie des objets cachés en cas de maj de la BD BD 130
  • 113. 01/01/2010 Les Antéserveurs (iii) Génération à intervalle régulier d ’une base documentaire à partir d ’une base de données Cas de données à faible variation et à caractère non transactionnelle Exemple : Catalogue de Produits remis à jour une fois par jour Requêtes SQL Batch SGBD BD Didier Donsez, 1995-2010, HTTP Tables SQL Copie en Génération 1- requête HTTP Client HTML 2- réponse HTML Online Serveur HTTPD Mise à Jour Copie Publiée Offline Pressage,Gravage, ... Copie distribuée sur support physique (DK,CD,DVD, …) 131
  • 114. 01/01/2010 Les Antéserveurs (iv) Génération et Indexation Full-Text Requêtes SQL Batch SGBD BD Tables SQL Mise à Jour Didier Donsez, 1995-2010, HTTP Copie en Génération 1- requête HTTP Client HTML 2- réponse HTML Online Serveur HTTPD Indexeur FullText Index Offline Copie Publiée Index 132
  • 115. 01/01/2010 Embedded Web Server (i) Rappel : HTTP est un protocole très répandu et très outillé Motivation Didier Donsez, 1995-2010, HTTP Dialoguer (piloter/administrer) avec des ordinateurs enfouis ou embarqués via HTTP Réseaux Routeurs, Coupleur réseaux domestiques (X10, Echelon, …) ou industriels (ModBus, …) .. Electronic consuming Téléphonie cellulaire, Répondeur domestique, … Domotique Proxy Domotique pilotant l’alarme, le chauffage, Frigidaire … Entertainement Network (UPnP) … TV, HIFI, Digital Camera, Consoles de Jeux, WiFi Toys … 133
  • 116. 01/01/2010 Embedded Web Server (ii) Serveur HTTP pour ordinateurs enfouis ou embarqués Empreinte mémoire réduite, CPU Passerelle OSGi (www.osgi.org) voir cours sur OSGi Sun’ JES (Java Embedded Server), OSCAR, … Didier Donsez, 1995-2010, HTTP Brazil Project, Apache PicoServer, ACME micro_httpd, TINIWebServer … HTTP sur « Silicium » Couches IP/TPC/HTTP directement incluses dans des DSP, … 134
  • 117. 01/01/2010 Embedded Web Server (iii) milliers de millions de capteurs/actionneurs passerelles frontières Internet mesures agrégées ou alarmes par milliers commandes par milliers serveurs applicatif requêtes par milliers serveur bases de données requêtes par milliers Didier Donsez, 1995-2010, HTTP mesures par millions Serveurs HTTP embarqués •passerelles domotiques, •passerelles immotiques, •passerelles véhiculaires, •passerelles industriels, … 135
  • 118. 01/01/2010 Serveurs Dédiés (ou Server Appliances) Motivations S’oppose aux serveurs généralistes Configurations matérielles et logicielles dédiées aux services Web OS: généralement un Linux « tuné », … HTTPD : Apache, … configuration Plug-and-Play et administration simple (console HTML, SMTP) Enpilable, Rackable, … Cibles : ISP et PME/PMI Didier Donsez, 1995-2010, HTTP Préconfiguration, configuration aisée, … Fonctionnalités HTTPD, Proxy, Cache, Firewall, Répartiteur de Charge, AntiVirus, Messagerie, … Mais aussi SGBD (Oracle), MediaCaster, Indexeur (Google Appliances) … Acteurs Cobalt (racheté par Sun), RightVision, Akamai et HP, IBM, … 136
  • 119. 01/01/2010 Clients HTTP dans le J2SE et J2ME Implémente directement un client HTTP J2SE et J2ME java.net.URL, java.net.URLConnection, java.net.HttpURLConnection javax.microedition.io.Connection, javax.microedition.io.HttpConnexion Jakarta HttpClient Tache Jakarta Ant/Nant <get> (<post> http://ant-contrib.sourceforge.net) Fonctionnalités Didier Donsez, 1995-2010, HTTP Suivi de session (indépendance de cookies serveurs), multipart request, WebDav (PUT,DELETE, LOCK, …), HTTP/SSL … Quelques Usages Robot de récupération, Injection de charge ... Déploiement automatique (Ant,Maven,WebDav) Tunneling HTTP, RPC sur HTTP (XMLRPC, SOAP/HTTP, JMX Adaptor) Voir le cours « Programmation Réseau en Java » 137
  • 120. 01/01/2010 HTTP dans HTML (i) Eléments META dans l ’élément HEAD d ’un document HTML 3.2 <META HTTP-EQUIV=name CONTENT=value> équivalent à ajouter des Header ’s pour documents statiques Didier Donsez, 1995-2010, HTTP <META HTTP-EQUIV="Expires" CONTENT=" Tue, 20 Aug 1996 14:25:27 GMT"> <META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com "> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache"> <META HTTP-EQUIV ="Content-Type" content="text/html; charset=iso-8859-1"> <META HTTP-EQUIV ="Set-Cookie" content="cookie=set; path=/"> Exemple <HTML><HEAD> <META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com "> </HEAD><BODY> <H1> This site moves to <A HREF=" http://newsite.mycomp.com "> http://newsite.mycomp.com </A></H1> </BODY></HTML> 138
  • 121. 01/01/2010 HTTP dans HTML (ii) Eléments META dans l ’élément HEAD d ’un document HTML 3.2 <META HTTP-EQUIV=name CONTENT=value> équivalent à ajouter des Header ’s pour documents statiques Didier Donsez, 1995-2010, HTTP <META HTTP-EQUIV="Expires" CONTENT=" Tue, 20 Aug 1996 14:25:27 GMT"> <META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com "> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache"> <META HTTP-EQUIV ="Content-Type" content="text/html; charset=iso-8859-1"> <META HTTP-EQUIV ="Set-Cookie" content="cookie=set; path=/"> Exemple <HTML><HEAD> <META HTTP-EQUIV="Refresh" CONTENT="3; URL= http://newsite.mycomp.com "> </HEAD><BODY> <H1> This site moves to <A HREF=" http://newsite.mycomp.com "> http://newsite.mycomp.com </A></H1> </BODY></HTML> 139
  • 122. 01/01/2010 HTTP dans HTML (iii) AJAX (Asynchronous JavaScript Technology and XML) Objet Javascript XMLHttpRequest permet d’invoquer des requêtes GET ou POST l’arbre DOM du résultat (XML ou HTML) peut être parcouru par le script Exemple Didier Donsez, 1995-2010, HTTP TODO 140
  • 123. 01/01/2010 WAP et WML Motivation Adapter HTTP et HTML aux « handsets » nomades Affichage limité, contrôle limité (i.e. clavier, pointage, …) Débit limité et coût de communication WAP Wireless Application Protocol Didier Donsez, 1995-2010, HTTP protocole HTTP « like » et « light » Utilise les couches réseaux des réseaux cellulaires (à la place d ’IP) Utilise la sécurité des réseaux cellulaires WML Wireless Markup Language langage hypertextuel adapté aux handsets nomades basé sur XML/DTD : il existe un format plus compact (bytecodé) voir www.wapforum.org et le cours sur WAP et WML 141
  • 124. 01/01/2010 WAP Architecture Réseau WML/HTTP WML/WAP Passerelle WAP Didier Donsez, 1995-2010, HTTP Réseau GSM Serveur WWW WML/HTTP Filtre Internet HTML HTTP Serveur WWW WML/WAP Filtre ProxyWAP WML/WAP Serveur TeleVAS HTML HTTP Serveur WWW WML/WAP WAP Handsets 142
  • 125. 01/01/2010 Faire du PUSH avec HTTP Motivation : le Push Une donnée sur le serveur change de valeur Le navigateur doit charger un document (généré) présentant la nouvelle valeur Problème Le serveur ne peut notifier le navigateur du changement Solution : le Polling Didier Donsez, 1995-2010, HTTP 1. Le navigateur recharge le document régulièrement Inconvénient: le réaffichage du document pertube l’utilisateur même si rien de nouveau arrive <META HTTP-EQUIV="Refresh" CONTENT="5"> 2. Une applet nichée scrute régulièrement auprès du serveur si la valeur à changer et provoque le rechargement de la page en cas de changement Remarque: la valeur du Refresh peut être adaptée au cours du temps 144
  • 126. 01/01/2010 Constrained Application Protocol (CoAP) Motivation : HTTP/REST-like protocol for constrained sensors 128KB FlashRAM and 4KB RAM Battery consumption (sleep and periodical wakeup) Interaction Request-response Subscribe-Notify REST (READ, WRITE, CREATE, DESTROY) Resource discovery /profile URI multicast + DISCOVER method Protocol binding Didier Donsez, 1995-2010, HTTP UDP and UDP Multicast (16-bit sequence number for reliability) Optionally TCP without “stop and wait” Caching Important since sleeping mode CoAP proxy (for subscription …) See http://www.ietf.org/id/draft-shelby-6lowapp-coap-00.txt 145
  • 127. 01/01/2010 Web 2.0 (TODO) Motivations Didier Donsez, 1995-2010, HTTP Composer l’interface de plusieurs sources fournisseurs Rendre les interfaces riches et fluides 146
  • 128. 01/01/2010 Technologies RIA (Rich Internet Application) Motivations Didier Donsez, 1995-2010, HTTP Constat : taux élevé des abandons lors d’une navigation sur les sites de e-Commerce Raisons (d’après une étude de Global Millennia Marketing) High shipping cost (69%) Change of mind (61%) High total cost (49%) Long checkout process (41%) Poor site navigation and long download times (31%) Confusing checkout process (27%) Solutions DHTML/AJAX, Flash, OpenLaszlo, … + RESTFul, JSON, … 147
  • 129. 01/01/2010 The Bayeux protocol Motivation « bi-directional » HTTP-based messaging for RIA Operation invocation RIA server data source, RESTful, SOAP, … Notification Server RIA state change, alert, completed Future object … Didier Donsez, 1995-2010, HTTP Principe Pull Polling Implementations JavaScript : Dojo’cometd … 148
  • 130. 01/01/2010 Bibliographie Beaucoup de Guides, Tutoriels, Manuels Didier Donsez, 1995-2010, HTTP http://ds.internic.net/rfc/rfc2068.txt http://www.w3.org http://fr.wikipedia.org/wiki/Hypertext_Transfer_Protocol Des livres Attention, ca change très vite ! La traduction en français a au moins 1 an de retard sur la version anglaise 149
  • 131. 01/01/2010 Bibliographie - HTTP Stephen Spainhour & Robert Eckstein, « Webmaster in a Nutshell », 2nd Edition, June 1999 (est.), ISBN 1-56592325-1, Ed : O'Reilly très complet Clinton Wong, « Programmation de clients Web avec Perl », Ed Oreilly, 1997, ISBN 2-84177-050-8 Didier Donsez, 1995-2010, HTTP l ’automatisation de requêtes sur HTTP (en Perl) Revues Duane Wessels , Web Caching, June 2001, Oreilly, 156592-536-X Patrick Killelea , Web Performance Tuning, 1st Edition October 1998, ISBN 1-56592-379-0 Revue IEEE Internet Computing http://www.computer.org/internet Revue IEEE IT Professional http://www.computer.org/itpro 150
  • 132. 01/01/2010 Bibliographie - Serveurs Didier Donsez, 1995-2010, HTTP Jason Brittain, Ian F. Darwin, "Tomcat: The Definitive Guide", Ed OReilly, June 2003, ISBN: 0-596-00318-8 151
  • 133. 01/01/2010 Bibliographie - Autres Robert Orfali, Dan Harkey, Jeri Edwards, « Client/Server Survival Guide », 3rd edition, February 1999, Ed John Wiley & Sons; ISBN: 0471316156 information générale sur les composants d ’un SI Didier Donsez, 1995-2010, HTTP Louis Rosenfeld, Peter Morville , "Information Architecture for the World Wide Web - Designing Large-scale Web Sites", 1st Edition February 1998, ISBN 1-56592-282-4,OReilly, 226 pages, $24.95 C. Leloup, “Moteurs d'Indexation et de Recherche”, Ed. Eyrolles, 1998, ISBN 2-212-08976-7 152