Cours 6. h)p, srcipt CGI, php Javascript Smtp, pop,imap, 6p



Documents pareils
Couche applica,on. h.p- web Cgi javascript

L3 informatique TP n o 2 : Les applications réseau

Gilles.Roussel univ-mlv.fr HTTP/1.1 RFC 2068

Internet. Web Sécurité Optimisation

HTTP HTTP. IUT1 dpt SRC L Isle d Abeau Jean-françois Berdjugin. Introduction et architecture Messages Authentification Conclusion

Divers éléments. Protocoles d'applications. Un agent Utilisateur. MUA - Agents Utilisateurs de Courriel. Simple Mail Transfer Protocol

Couche application 1

CGI et SSI. La programmation CGI. Sources. Objectifs. Qu'est ce qu'un programme CGI? CGI

HTTP 1.1. HyperText Transfer Protocol TCP IP ...

Serveurs de noms Protocoles HTTP et FTP

Protocoles Applicatifs

Zoom sur Newtest LDAP intégration

Le serveur HTTPd WASD. Jean-François Piéronne

Dans l'épisode précédent

Instructions Mozilla Thunderbird Page 1

FTP & SMTP. Deux applications fondamentales pour le réseau Internet.

Développement Web. Les protocoles

Couche application. La couche application est la plus élevée du modèle de référence.

FTP & SMTP. File Transfert Protocol. Deux applications fondamentales pour le réseau Internet. Un protocole d échange de fichier «au dessus» de TCP :

Serveurs et environnements de développement. Serveur Web

L envoi d un formulaire par courriel. Configuration requise Mail Texte Mail HTML Check-list

TP HTTP. Université Pierre Mendès France U.F.R. Sciences de l Homme et de la Société Master IC²A

VTP. LAN Switching and Wireless Chapitre 4

Types MIME (2) Typage des ressources Internet. Les URI. Syntaxe dans les URI. Possibilité de spécifier un paramètre du sous-type

Failles XSS : Principes, Catégories Démonstrations, Contre mesures

Quick Start Guide This guide is intended to get you started with Rational ClearCase or Rational ClearCase MultiSite.

Tutoriel de formation SurveyMonkey

Chapitre : Les Protocoles

(structure des entêtes)

NOTICE INSTALLATION. ARCHANGE WebDAV Office N&B/Couleur KONICA MINOLTA BUSINESS SOLUTIONS FRANCE

Module 7 : Configuration du serveur WEB Apache

Utiliser une WebCam. Micro-ordinateurs, informations, idées, trucs et astuces

Introduction à HTTP. Chapitre HTTP 0.9

INF8007 Langages de script

Réseaux. 1 Généralités. E. Jeandel

titre : CENTOS_CUPS_install&config Système : CentOs 5.7 Technologie : Cups Auteur : Charles-Alban BENEZECH

Outils de l Internet

Hébergement de site web Damien Nouvel

Bases de données et Interfaçage Web

«Cachez-moi cette page!»

Outils d'analyse de la sécurité des réseaux. HADJALI Anis VESA Vlad

Plan. Le système de transfert de fichiers d'internet. Introduction aux systèmes de transfert de fichiers Le protocole FTP.

Application Web et J2EE

Installation UpdatEngine serveur (CentOs apache2 / MySQL)

HAUTE DISPONIBILITÉ DE MACHINE VIRTUELLE AVEC HYPER-V 2012 R2 PARTIE CONFIGURATION OPENVPN SUR PFSENSE

WEB page builder and server for SCADA applications usable from a WEB navigator

1 Configuration des Fichiers Hosts, Hostname, Resolv.conf

TABLE DES MATIERES A OBJET PROCEDURE DE CONNEXION

18 TCP Les protocoles de domaines d applications

How to Login to Career Page

I>~I.J 4j1.bJ1UlJ ~..;W:i 1U

Les sites Internet dynamiques. contact : Patrick VINCENT pvincent@erasme.org

1 Introduction Propos du document Introduction De HTTP 1.0 à HTTP

Gestion centralisée d un réseau de sites discrets. Nicolas JEAN

NOTICE INSTALLATION. ARCHANGE Simplex Office N&B/Couleur KONICA MINOLTA BUSINESS SOLUTIONS FRANCE

SERVEUR HTTP Administration d apache

SSH, le shell sécurisé

Supervision et infrastructure - Accès aux applications JAVA. Document FAQ. Page: 1 / 9 Dernière mise à jour: 15/04/12 16:14

Un serveur web léger et ouvert

Once the installation is complete, you can delete the temporary Zip files..

lundi 3 août 2009 Choose your language What is Document Connection for Mac? Communautés Numériques L informatique à la portée du Grand Public

Hébergement WeboCube. Un système performant et sécurisé. Hébergement géré par une équipe de techniciens

Table des matières ENGLISH VERSION NEAR BOTTOM OF PAGE. Transferts sécurisés de fichiers Système MFT (Managed File Transfer) Guide de l utilisateur

Vanilla : Virtual Box

Les techniques de la télémaintenance

WiFi Security Camera Quick Start Guide. Guide de départ rapide Caméra de surveillance Wi-Fi (P5)

Module Com231A - Web et Bases de Données Notion 5 : Formulaires et utilisation des Bases de Données avec PHP

Installation d un serveur HTTP (Hypertext Transfer Protocol) sous Débian 6

Module pour la solution e-commerce Magento

Le protocole HTTP. 10 minutes pour comprendre. HTTP/0.9 - Lacunes et limitations HTTP/1.0 HTTP/1.1

LOGICIEL D'ADMINISTRATION POUR E4000 & G4000 MANAGEMENT SOFTWARE FOR E4000 & G4000

Installer un domaine DNS

Attaques applicatives

Micro-ordinateurs, informations, idées, trucs et astuces utiliser le Bureau à distance

Stockage du fichier dans une table mysql:

Les solutions de paiement CyberMUT (Crédit Mutuel) et CIC. Qui contacter pour commencer la mise en place d une configuration de test?

Application Form/ Formulaire de demande

Préparation d un serveur Apache pour Zend Framework

Bon ben voilà c est fait!

Table des matières Hakim Benameurlaine 1

INSTALLATION DE WINDOWS 2000 SERVER POUR BCDI3. par. G.Haberer, A.Peuch, P.Saadé

Table des matières. 1. Installation de VMware ESXI Pré-requis Installation... 3

SUGARCRM Sugar Open Source Guide d Installation de French SugarCRM Open Source Version 4.2

SIP. Plan. Introduction Architecture SIP Messages SIP Exemples d établissement de session Enregistrement

Imprimantes et partage réseau sous Samba avec authentification Active Directory

Protocole applicatif. Quel est le service de transport nécessaire à une application? Besoin en service de transport

Sécurité des sites Web Pas un cours un recueil du net. INF340 Jean-François Berdjugin

DOCUMENTATION - FRANCAIS... 2

Réseaux et protocoles Damien Nouvel

PHP et mysql. Code: php_mysql. Olivier Clavel - Daniel K. Schneider - Patrick Jermann - Vivian Synteta Version: 0.9 (modifié le 13/3/01 par VS)

INTERNET est un RESEAU D ORDINATEURS RELIES ENTRE EUX A L ECHELLE PLANETAIRE. Internet : interconnexion de réseaux (anglais : net = réseau)

Tutoriel compte-rendu Mission 1

Packet Tracer : configuration des listes de contrôle d'accès étendues, scénario 1

PHP et les Bases de données - Généralités

Acce s aux applications informatiques Supply Chain Fournisseurs

Quelques protocoles et outils réseaux

Comment Accéder à des Bases de Données MySQL avec Windows lorqu'elles sont sur un Serveur Linux

Installation d'un serveur RADIUS

Transcription:

Cours 6 h)p, srcipt CGI, php Javascript Smtp, pop,imap, 6p

HTTP request message two types of HTTP messages: request, response HTTP request message: ASCII (human-readable format) request line (GET, POST, HEAD commands) Carriage return, line feed indicates end of message header lines GET /somedir/page.html HTTP/1.1 Host: www.someschool.edu User-agent: Mozilla/4.0 Connection: close Accept-language:fr (extra carriage return, line feed) M2-Internet 2

HTTP request message: general format M2-Internet 3

Uploading form input Post method: Web page often includes form input Input is uploaded to server in entity body URL method: Uses GET method Input is uploaded in URL field of request line: www.somesite.com/animalsearch?monkeys&banana M2-Internet 4

Method types HTTP/1.0 GET POST HEAD asks server to leave requested object out of response HTTP/1.1 GET, POST, HEAD PUT uploads file in entity body to path specified in URL field DELETE deletes file specified in the URL field M2-Internet 5

POST dans une requête POST les données sont dans le corps du message les données définissent des variables qui seront utilisées par le CGI l'url requise est normalement un programme la réponse HTTP est normalement la sortie d'un programme M2-Internet 6

HTTP response message status line (protocol status code status phrase) data, e.g., requested HTML file header lines HTTP/1.1 200 OK Connection close Date: Thu, 06 Aug 1998 12:00:15 GMT Server: Apache/1.3.0 (Unix) Last-Modified: Mon, 22 Jun 1998... Content-Length: 6821 Content-Type: text/html data data data data data... M2-Internet 7

HTTP response status codes In first line in server->client response message. A few sample codes: 200 OK request succeeded, requested object later in this message 301 Moved Permanently requested object moved, new location specified later in this message (Location:) 400 Bad Request request message not understood by server 404 Not Found requested document not found on this server 505 HTTP Version Not Supported M2-Internet 8

Trying out HTTP (client side) for yourself 1. Telnet to your favorite Web server: telnet cis.poly.edu 80 Opens TCP connection to port 80 (default HTTP server port) at cis.poly.edu. Anything typed in sent to port 80 at cis.poly.edu 2. Type in a GET HTTP request: GET /~ross/ HTTP/1.1 Host: cis.poly.edu By typing this in (hit carriage return twice), you send this minimal (but complete) GET request to HTTP server 3. Look at response message sent by HTTP server! M2-Internet 9

Méthodes http GET HEAD POST C'est la méthode la plus courante pour demander une ressource. Une requête GET est sans effet sur la ressource, il doit être possible de répéter la requête sans effet. Cette méthode ne demande que des informations sur la ressource, sans demander la ressource elle-même. Cette méthode doit être utilisée lorsqu'une requête modifie la ressource. OPTIONS Cette méthode permet d'obtenir les options de communication d'une ressource ou du serveur en général. CONNECT TRACE PUT Cette méthode permet d'utiliser un proxy comme un tunnel de communication. Cette méthode demande au serveur de retourner ce qu'il a reçu, dans le but de tester et effectuer un diagnostic sur la connexion. DELETE Cette méthode permet d'ajouter une ressource sur le serveur. Cette méthode permet de supprimer une ressource du serveur. M2-Internet 10

entêtes Host Permet de préciser le site Web concerné par la requête, ce qui est nécessaire pour un serveur hébergeant plusieurs sites à la même adresse IP (name based Referer virtual host, hôte virtuel basé sur le nom). (Obligatoire) Indique l'uri du document qui a donné un lien sur la ressource demandée. Cet entête permet aux webmasters d'observer d'où viennent les visiteurs. User-Agent Indique le logiciel utilisé pour se connecter. Il s'agit généralement d'un navigateur Web ou d'un robot d'indexation. Connection Accept connection persistante ou non Cet en-tête liste les types MIME de contenu acceptés par le client. Le caractère étoile * peut servir à spécifier tous les types / sous-types. Accept-Charset Spécifie les encodages de caractères acceptés. Accept-Language Spécifie les langues acceptés. M2-Internet 11

Réponses Date Moment auquel le message est généré. Server Indique quel modèle de serveur HTTP répond à la requête. Content-Length Indique la taille en octets de la ressource. Content-Type Indique le type MIME de la ressource. Expires Indique le moment après lequel la ressource devrait être considérée obsolète ; permet aux navigateurs Web de déterminer jusqu'à quand garder la ressource en mémoire cache. Last-Modified Indique la date de dernière modification de la ressource demandée. M2-Internet 12

User-server state: cookies Many major Web sites use cookies Four components: 1) cookie header line of HTTP response message 2) cookie header line in HTTP request message 3) cookie file kept on user s host, managed by user s browser 4) back-end database at Web site Example: Susan access Internet always from same PC She visits a specific e- commerce site for first time When initial HTTP requests arrives at site, site creates a unique ID and creates an entry in backend database for ID M2-Internet 13

Cookies: keeping state (cont.) Cookie file ebay: 8734 client usual http request msg usual http response + Set-cookie: 1678 server server creates ID 1678 for user Cookie file amazon: 1678 ebay: 8734 one week later: Cookie file amazon: 1678 ebay: 8734 usual http request msg cookie: 1678 usual http response msg usual http request msg cookie: 1678 usual http response msg cookiespecific action cookiespectific action M2-Internet 14

Cookies (continued) What cookies can bring: authorization shopping carts recommendations user session state (Web e-mail) aside Cookies and privacy: cookies permit sites to learn a lot about you you may supply name and e-mail to sites search engines use redirection & cookies to learn yet more advertising companies obtain info across sites M2-Internet 15

Web caches (proxy server) Goal: satisfy client request without involving origin server user sets browser: Web accesses via cache browser sends all HTTP requests to cache object in cache: cache returns object else cache requests object from origin server, then returns object to client client client Proxy server origin server origin server M2-Internet 16

More about Web caching Cache acts as both client and server Typically cache is installed by ISP (university, company, residential ISP) Why Web caching? Reduce response time for client request. Reduce traffic on an institution s access link. Internet dense with caches enables poor content providers to effectively deliver content (but so does P2P file sharing) M2-Internet 17

Caching example Assumptions average object size = 100,000 bits avg. request rate from institution s browsers to origin servers = 15/sec delay from institutional router to any origin server and back to router = 2 sec Consequences utilization on LAN = 15% utilization on access link = 100% total delay = Internet delay + access delay + LAN delay = 2 sec + minutes + milliseconds institutional network public Internet 1.5 Mbps access link 10 Mbps LAN institutional cache origin servers M2-Internet 18

Caching example (cont) Possible solution increase bandwidth of access link to, say, 10 Mbps Consequences utilization on LAN = 15% utilization on access link = 15% Total delay = Internet delay + access delay + LAN delay = 2 sec + msecs + msecs often a costly upgrade institutional network public Internet 10 Mbps access link 10 Mbps LAN origin servers institutional cache M2-Internet 19

Caching example (cont) Install cache suppose hit rate is.4 Consequence 40% requests will be satisfied almost immediately 60% requests satisfied by origin server utilization of access link reduced to 60%, resulting in negligible delays (say 10 msec) total avg delay = Internet delay + access delay + LAN delay =.6*(2.01) secs + milliseconds < 1.4 secs institutional network public Internet 1.5 Mbps access link 10 Mbps LAN institutional cache origin servers M2-Internet 20

Conditional GET Goal: don t send object if cache has up-to-date cached version cache: specify date of cached copy in HTTP request If-modified-since: <date> server: response contains no object if cached copy is upto-date: HTTP/1.0 304 Not Modified cache HTTP request msg If-modified-since: <date> HTTP response HTTP/1.0 304 Not Modified HTTP request msg If-modified-since: <date> HTTP response HTTP/1.0 200 OK <data> server object not modified object modified M2-Internet 21

Préliminaire http est un protocole qui définit des formats pour les interactions entre serveurs et clients Du côté du client: les navigateurs Du côté serveur: des serveurs http Apache (httpd), IIS (internet information service) microsoft, Zeux etc Mais aussi des serveurs d'application comme glassfish ou tomcat M2-Internet 22

apache Pour pouvoir tester les exemples on utilisera apache logiciel libre disponible sur la plupart des plateformes Le serveur le plus fréquent Prise en charge de nombreux modules, (perl php, python, ruby ) cgi Serveurs virtuels M2-Internet 1-23

Principes Le serveur reçoit des requêtes http et renvoie des pages html dans des réponses http Interpréter les requêtes Lancer sur le côté serveur les applications concernées Récupérer les résultats et les transmettre au client Configuration: httpd.conf (en général dans /etc (et par catalogue.htaccess) M2-Internet 1-24

Principes Correspondance entre url et fichiers locaux DocumentRoot: Si DocumentRoot = /var/www/html http://www.exemple.com/un/deux.html sera converti en /var/www/html/un/deux.html Pages des uitlisateurs UserDir: www http://www.example.com/~user/file.html sera /home/user/public_html/file.html En plus des alias et des redirections M2-Internet 1-25

Pour voir Sur cette machine: /private/etc/apache2/httpd.conf ServerRoot: /usr DocumentRoot: /Library/WebServer/Documents + fichier de configurations dans «extra» UserDir: Sites M2-Internet 1-26

CGI Common Gateway Interface exécuter du code du côté serveur Passage de paramètre par la méthode POST ou la méthode GET Variables d'environnement M2-Internet 27

Pour Apache Les executables cgi ScriptAlias /cgi-bin/ /usr/local/apache2/cgi-bin/ Pour http://www.example.com/cgi-bin/test.pl /usr/local/apache2/cgi-bin/test.pl sera exécuté "Paramètres" POST: transmis sur l'entrée standard (STDIN) GET: variable de l'environnement QUERY_STRING STDOUT pour la réponse (au moins un MIME type header Content-type: text/html et deux newline) M2-Internet 28

Exemple en shell: date.cgi #!/bin/sh tmp=`/bin/date` echo "Content-type: text/html\n <HTML><HEAD><TITLE>Script Cgi</TITLE></ HEAD><BODY> <CENTER> <H1>La date courante sur le serveur est</h1> $tmp </CENTER> </BODY> </HTML>" l'url affichera la date http://localhost/cgi-bin/date.cgi M2-Internet 29

Avec un formulaire: <HTML><HEAD><TITLE>Formulaire simple</title></head> <BODY> <H2>Répondez aux questions suivantes</h2> <FORM ACTION="http://www.monsite.com/cgi-bin/treat.pl" METHOD=GET> Prénom : <INPUT TYPE="text" NAME=prenom SIZE=20><BR> Nom : <INPUT TYPE="text" NAME=nom SIZE=20><BR> Age : <SELECT NAME=age> <OPTION>- de 18 ans <OPTION>19 à 40 ans <OPTION>41 à 60 ans <OPTION>+ de 60 ans </SELECT><BR> <INPUT TYPE=submit VALUE="Envoyer"> <INPUT TYPE=reset VALUE="Remettre à zéro"> </FORM> </BODY> http://localhost/~hf/formulaire.html M2-Internet 30

Résultat par la méthode get codage des paramètres: prenom=hugues&nom=fauconnier&age= 41+%E0+60+ans le navigateur génère l'url: http://www.monsite.com/cgi-bin/treat.pl? prenom=hugues&nom=fauconnier&age=41+%e0+60+ans Avec la méthode POST http://www.monsite.com/cgi-bin/treat.pl prenom=hugues&nom=fauconnier&age=41 M2-Internet 31

Traitement en perl fichier perl M2-Internet 32

Paramètres Les paramètres sont accessibles par l'intermédiaire de la variable d'environnement QUERY_STRING M2-Internet 33

Variables d'environnement SERVER_SOFTWARE Le nom et la version du serveur HTTP répondant à la requête. (Format : nom/version) SERVER_NAME Le nom d'hôte, alias DNS ou adresse IP du serveur. GATEWAY_INTERFACE La révision de la spécification CGI que le serveur utilise. (Format : CGI/révision) M2-Internet 34

Variables SERVER_PROTOCOL Le nom et la révision du protocole dans lequel la requête a été faite (Format : protocole/révision) SERVER_PORT Le numéro de port sur lequel la requête a été envoyée. REQUEST_METHOD La méthode utilisée pour faire la requête. Pour HTTP, elle contient généralement «GET» ou «POST». PATH_INFO Le chemin supplémentaire du script tel que donné par le client. Par exemple, si le serveur héberge le script «/cgi-bin/ monscript.cgi» et que le client demande l'url «http:// serveur.org/cgi-bin/monscript.cgi/marecherche», alors PATH_INFO contiendra «marecherche». PATH_TRANSLATED Contient le chemin demandé par le client après que les conversions virtuel physique aient été faites par le serveur. M2-Internet 35

Variables SCRIPT_NAME Le chemin virtuel vers le script étant exécuté. Exemple : «/cgibin/script.cgi» QUERY_STRING Contient tout ce qui suit le «?» dans l'url envoyée par le client. Toutes les variables provenant d'un formulaire envoyé avec la méthode «GET» sera contenue dans le QUERY_STRING sous la forme «var1=val1&var2=val2&...». REMOTE_HOST Le nom d'hôte du client. Si le serveur ne possède pas cette information (par exemple, lorsque la résolution DNS inverse est désactivée), REMOTE_HOST sera vide. REMOTE_ADDR L'adresse IP du client. AUTH_TYPE Le type d'identification utilisé pour protéger le script (s il est protégé et si le serveur supporte l'identification). M2-Internet 36

Variables AUTH_TYPE Le type d'identification utilisé pour protéger le script (s il est protégé et si le serveur supporte l'identification). REMOTE_USER Le nom d'utilisateur du client, si le script est protégé et si le serveur supporte l'identification. REMOTE_IDENT Nom d'utilisateur (distant) du client faisant la requête. Le serveur doit supporter l'identification RFC 931. Cette variable devraient être utilisée à des fins de journaux seulement. CONTENT_TYPE Le type de contenu attaché à la requête, si des données sont attachées (comme lorsqu'un formulaire est envoyé avec la méthode «POST»). CONTENT_LENGTH La longueur du contenu envoyé par le client. M2-Internet 37

Variables HTTP_ACCEPT Les types de données MIME que le client accepte de recevoir. Exemple : text/*, image/jpeg, image/png, image/*, */* HTTP_ACCEPT_LANGUAGE Les langages dans lequel le client accepte de recevoir la réponse. Exemple : fr_ca, fr HTTP_USER_AGENT Le navigateur utilisé par le client. Exemple : Mozilla/5.0 (compatible; Konqueror/3; Linux) M2-Internet 38

Compléments Javascript Code qui s'exécute du côté du client calcul local contrôle d'une zone de saisie affichage d'alerte fenêtres menus etc.. Balise : <SCRIPT languge="javascript1.2"> le code... </SCRIPT> M2-Internet 39

Exemple: bonjour <HTML><HEAD> <TITLE>Très facile</title> </HEAD> <SCRIPT language="javascript1.2"> function bonjour() { alert ("Bonjour madame, bonjour monsieur"); } </SCRIPT> <BODY bgcolor="white" onload="bonjour();"> <H1>Bonjour</H1> </BODY></HTML> http://localhost/~hf/bjrjvs.html M2-Internet 40

Un peu plus: minicalcul <HTML> <HEAD> <TITLE>Petit calcul</title> </HEAD> <BODY bgcolor='white'> <script language='javascript1.2' src='calcul.js'></script> <script language='javascript1.2' src='fenetre.js'></script> <script language='javascript1.2' src='ctrl.js'></script> <CENTER><H1>Calcul</H1></CENTER> Un petit exemple de formulaire. <P> Création d'une <A href='#a' onclick='affichedoc();'>fenêtre avec JavaScript</A> M2-Internet 41

Suite <FORM ACTION='Simul.html' METHOD='POST' NAME='Simul'> <CENTER> <TABLE BORDER=3> <TR><TD>Argument 1 <TD> <INPUT TYPE='TEXT' SIZE=20 NAME='arg1' onchange='calcul();'></tr> <TR><TD>* Argument 2 <TD> <INPUT TYPE='TEXT' SIZE=20 NAME='arg2' onchange='calcul();'> </TR> <TR><TD>Résultat= <TD> <INPUT TYPE='TEXT' SIZE=20 NAME='res' > </TR> </TABLE> <INPUT TYPE='BUTTON' VALUE='Vérifier' onclick='ctrl();'> <INPUT TYPE='RESET' VALUE='Effacer tout' onclick=' if (!confirm("vraiment vous voulez effacer?")) exit;'> </CENTER> </FORM> </BODY> </HTML> http://localhost/~hf/simul.html M2-Internet 42

Fichiers js Ctrl.js calcul function ctrl() { if (isnan(window.document.simul.res.value )) { alert ("Valeur incorrecte : " + document.simul.res.value + "?"); document.forms[0].res.focus(); } } function calcul() { v1=document.forms[0].arg1.value; v2=document.forms[0].arg2.value; document.forms[0].res.value = v2*v1 ; } M2-Internet 43

suite et fin exemples/fenetre.js function affichedoc() { options = "width=300,height=200"; fenetre = window.open('','mu',options); } fenetre.document.open(); manuel = "<HTML><HEAD><TITLE>Documentation</TITLE></ HEAD>" + "<BODY bgcolor='white'>" + "Il n'y a pas besoin d'aide " + " c'est facile." + " Bonne chance!</body></html>"; fenetre.document.write(manuel); fenetre.document.close(); M2-Internet 44

Compléments: php php est un langage de script pour les serveurs webs de nombreuses fonctions permettent de traiter les requêtes http (en particulier des requêtes concernant des bases de données) ici on est du côté du serveur M2-Internet 45

Exemple simple <HTML> <HEAD> <TITLE>Exemple très simple</title> </HEAD> <BODY> <H1>Exemple</H1> le <?php echo Date ("j/m/y à H:i:s");?> <P> <?php echo "Client :". $_SERVER['HTTP_USER_AGENT']. "<BR>"; echo "Adresse IP client:".$_server['remote_addr']."<br>"; echo "Server: ". $_SERVER['SERVER_NAME'];?> </BODY></HTML> http://localhost/~hf/exemplesimple.php M2-Internet 46

Résultat Exemple le 8/11/2006 à 15:54:29 Client :Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1;.NET CLR 1.1.4322; InfoPath.1) Adresse IP client:127.0.0.1 Server: localhost M2-Internet 47

Reçu par le client <HTML> <HEAD> <TITLE>Exemple très simple</title> </HEAD> <BODY> <H1>Exemple</H1> le 8/11/2006 à 15:54:29 <P> Client :Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1;.NET CLR 1.1.4322; InfoPath.1)<BR>Adresse IP client: 127.0.0.1<BR>Server: localhost </BODY></HTML> M2-Internet 48

Php On est ici côté serveur: les balises <?php> <?> sont interprétées par le serveur (apache par exemple) et servent à générer la page html reçue par le client Mais surtout php permet d'accéder aux variables d'environnement d'utiliser de nombreuses fonctionnalités sessions, paramètres etc. Php sert souvent d'interface pour MySql serveur simple de bases de données M2-Internet 49

Php pas de typage ni de déclaration des variables $v est remplacé par la valeur de v (et permet aussi l'affectation) echo "$v"; constantes define("pi, 3.1415); types des variables numériques $i=1; $v=3.14; chaînes de caractères (expressions régulières) $nom="hugues"; ',",{} M2-Internet 50

php Variables Locales (à une fonction) Globales Super globales (disponibles dans tout contexte) Static (garde sa valeur) Variables dynamiques (le nom de la variable est une variable) $a='bonjour' $$a='monde' echo "$a ${$a}" echo "$a $bonjour" M2-Internet 51

php tableaux indicés $tab[0]="un"; $tab=array("un","deux","trois"); associatifs $m=array("un"=>"one", "deux"=>"two"); $m["trois"]="three"; next() prev() key() current do {echo "Clé=key($m).Valeur= current($m)"} while(next($mes)); foreach($m as $cle =>$val) {echo "Clé=$cle.Valeur=$val";} M2-Internet 52

php Mais aussi (php4 et php5) Programmation orientée objets Classes et Objets Liaison dynamique Constructeurs Exceptions M2-Internet 53

Php structures de contrôles if if else while do while for foreach break, continue M2-Internet 54

fonctions function Nom([$arg1, $arg2,...]) { corps } passage par valeur (et par référence &) exemples function Add($i,$j){ $somme= $i + $j; return $somme; } function Add($i,$j,&$somme){ $somme= $i + $j; } M2-Internet 55

Pour le serveur tableaux associatifs prédéfinis $_SERVER: environnement serveur REQUEST_METHOD QUERY_STRING CONTENT_LENGTH SERVER_NAME PATH_INFO HTTP_USER_AGENT REMOTE_ADDR REMOTE_HOST REMOTE_USER REMOTE_PASSWORD M2-Internet 56

Suite Autres tableaux $_ENV : environnement système $_COOKIE $_GET $_POST $_FILES $_REQUEST (variables des 4 précédents) $_SESSION $GLOBALS les variables globales du script M2-Internet 57

Cookies et php <?php // Est-ce que le Cookie existe? if (isset($_cookie['compteur'])) { $message = "Vous êtes déjà venu {$_COOKIE['compteur']} fois ". "me rendre visite<br>\n"; // On incrémente le compteur $valeur = $_COOKIE['compteur'] + 1; } else { // Il faut créer le cookie avec la valeur 1 $message = "Bonjour, je vous envoie un cookie<br>\n"; $valeur = 1; } // Envoi du cookie SetCookie ("compteur", $valeur);?> M2-Internet 58

Cookies et php (fin) <HTML><HEAD> <TITLE>Les cookies</title> </HEAD> <BODY> <H1>Un compteur d'accès au site avec cookie</h1> <?php echo $message;?> </BODY></HTML> http://localhost/~hf/setcookie.php M2-Internet 59

En utilisant les sessions <?php // La fonction session_start fait tout le travail session_start();?> <HTML><HEAD> <TITLE>Les cookies</title> </HEAD> <BODY> <H1>Un compteur d'accès au site avec Session</H1> M2-Internet 60

Fin <?php if (!isset($_session['cp'])) { $_SESSION['cp']=1; echo "C'estlapremière fois,votre id est:". session_id()."<br>"; } else{ $_SESSION['cp']++; echo "C'est votre ".$_SESSION['cp']." n-ième connexion"; if($_session['cp']>10){ echo "on vous a trop vu"."<br>"; session_destroy(); } }?> </BODY></HTML> http://localhost/~hf/sessionphp.php M2-Internet 61

session session_start() session_destroy() session_id() on peut associer des variables à la session par le tableau associatif $_SESSION elle sera accessible à chaque session_start() jusqu'au session_destroy() pour toute connexion qui fournit le session_id(). M2-Internet 62

Chapter 2: Application layer 2.1 Principles of network applications 2.2 Web and HTTP 2.3 FTP 2.4 Electronic Mail SMTP, POP3, IMAP 2.5 DNS 2.6 P2P applications 2.7 Socket programming with UDP 2.8 Socket programming with TCP M2-Internet 63

FTP: the file transfer protocol FTP user interface FTP client file transfer FTP server user at host local file system remote file system transfer file to/from remote host client/server model client: side that initiates transfer (either to/from remote) server: remote host ftp: RFC 959 ftp server: port 21 M2-Internet 64

FTP: separate control, data connections FTP client contacts FTP server at port 21, TCP is transport protocol client authorized over control connection client browses remote directory by sending commands over control connection. when server receives file transfer command, server opens 2 nd TCP connection (for file) to client after transferring one file, server closes data connection. FTP client TCP control connection port 21 TCP data connection port 20 FTP server server opens another TCP data connection to transfer another file. control connection: out of band FTP server maintains state : current directory, earlier authentication M2-Internet 65

FTP commands, responses Sample commands: sent as ASCII text over control channel USER username PASS password LIST return list of file in current directory RETR filename retrieves (gets) file STOR filename stores (puts) file onto remote host Sample return codes status code and phrase (as in HTTP) 331 Username OK, password required 125 data connection already open; transfer starting 425 Can t open data connection 452 Error writing file M2-Internet 66

Chapter 2: Application layer 2.1 Principles of network applications 2.2 Web and HTTP 2.3 FTP 2.4 Electronic Mail SMTP, POP3, IMAP 2.5 DNS 2.6 P2P applications 2.7 Socket programming with UDP 2.8 Socket programming with TCP M2-Internet 67

Electronic Mail outgoing message queue user mailbox Three major components: user agents mail servers simple mail transfer protocol: SMTP User Agent a.k.a. mail reader composing, editing, reading mail messages e.g., Eudora, Outlook, elm, Mozilla Thunderbird outgoing, incoming messages stored on server mail server SMTP mail server user agent user agent SMTP SMTP user agent mail server user agent user agent user agent M2-Internet 68

Electronic Mail: mail servers Mail Servers mailbox contains incoming messages for user message queue of outgoing (to be sent) mail messages SMTP protocol between mail servers to send email messages client: sending mail server mail server SMTP mail server user agent SMTP SMTP mail server user agent user agent user agent server : receiving mail server user agent user agent M2-Internet 69

Electronic Mail: SMTP [RFC 2821] uses TCP to reliably transfer email message from client to server, port 25 direct transfer: sending server to receiving server three phases of transfer handshaking (greeting) transfer of messages closure command/response interaction commands: ASCII text response: status code and phrase messages must be in 7-bit ASCII M2-Internet 70

Scenario: Alice sends message to Bob 1) Alice uses UA to compose message and to bob@someschool.edu 2) Alice s UA sends message to her mail server; message placed in message queue 3) Client side of SMTP opens TCP connection with Bob s mail server 4) SMTP client sends Alice s message over the TCP connection 5) Bob s mail server places the message in Bob s mailbox 6) Bob invokes his user agent to read message 1 user agent mail mail server server 2 3 4 5 6 user agent M2-Internet 71

Sample SMTP interaction S: 220 hamburger.edu C: HELO crepes.fr S: 250 Hello crepes.fr, pleased to meet you C: MAIL FROM: <alice@crepes.fr> S: 250 alice@crepes.fr... Sender ok C: RCPT TO: <bob@hamburger.edu> S: 250 bob@hamburger.edu... Recipient ok C: DATA S: 354 Enter mail, end with "." on a line by itself C: Do you like ketchup? C: How about pickles? C:. S: 250 Message accepted for delivery C: QUIT S: 221 hamburger.edu closing connection M2-Internet 72

Try SMTP interaction for yourself: telnet servername 25 see 220 reply from server enter HELO, MAIL FROM, RCPT TO, DATA, QUIT commands above lets you send email without using email client (reader) M2-Internet 73

SMTP: final words SMTP uses persistent connections SMTP requires message (header & body) to be in 7- bit ASCII SMTP server uses CRLF.CRLF to determine end of message Comparison with HTTP: HTTP: pull SMTP: push both have ASCII command/response interaction, status codes HTTP: each object encapsulated in its own response msg SMTP: multiple objects sent in multipart msg M2-Internet 74

Mail message format SMTP: protocol for exchanging email msgs RFC 822: standard for text message format: header lines, e.g., To: From: Subject: different from SMTP commands! body the message, ASCII characters only header body blank line M2-Internet 75

Message format: multimedia extensions MIME: multimedia mail extension, RFC 2045, 2056 additional lines in msg header declare MIME content type MIME version method used to encode data multimedia data type, subtype, parameter declaration encoded data From: alice@crepes.fr To: bob@hamburger.edu Subject: Picture of yummy crepe. MIME-Version: 1.0 Content-Transfer-Encoding: base64 Content-Type: image/jpeg base64 encoded data.........base64 encoded data M2-Internet 76

MIME Multipurpose Internet Mail Extensions texte en caractères non US ASCII attachements messages en plusieurs parties défini dans l'entête du mail à l'origine pour le mail uniquement mais utilisé de plus en plus fréquemment (exemple HTTP) SMTP ne considère que des caractères ASCII 7 bits d'où la nécessité de codage décodage M2-Internet 77

MIME Un message peut être en plusieurs parties (multipart) définies par l'entête "Content- Type" exemple Content-Type: text/plain L'entête d'un message peut contenir autre chose que du US ASCII (par exemple dans le champ SUBJECT: "=?charset?encoding? encoded text?=". Subject: =?utf-8?q?=c2=a1hola,_se=c3=b1or!?= (Subject: Hola, señor!) M2-Internet 78

MIME Exemple de multipart Message: Content-type: multipart/mixed; boundary="frontier" MIME-version: 1.0 This is a multi-part message in MIME format. --frontier Content-type: text/plain This is the body of the message. --frontier Content-type: application/octet-stream Content-transfer-encoding: base64 PGh0bWw+CiAgPGhlYWQ +CiAgPC9oZWFkPgogIDxib2R5PgogICAgAVGhpcyBpcyB0a GUgYm9keSBvZiB0aGUgbWVzc2FnZS48L3A +CiAgPC9ib2R5Pgo8L2h0bWw+Cg== --frontier-- M2-Internet 79

Mail access protocols user agent SMTP SMTP access protocol user agent sender s mail server receiver s mail server SMTP: delivery/storage to receiver s server Mail access protocol: retrieval from server POP: Post Office Protocol [RFC 1939] authorization (agent <-->server) and download IMAP: Internet Mail Access Protocol [RFC 1730] more features (more complex) manipulation of stored msgs on server HTTP: gmail, Hotmail, Yahoo! Mail, etc. M2-Internet 80

POP3 protocol authorization phase client commands: user: declare username pass: password server responses +OK -ERR transaction phase, client: list: list message numbers retr: retrieve message by number dele: delete quit S: +OK POP3 server ready C: user bob S: +OK C: pass hungry S: +OK user successfully logged on C: list S: 1 498 S: 2 912 S:. C: retr 1 S: <message 1 contents> S:. C: dele 1 C: retr 2 S: <message 1 contents> S:. C: dele 2 C: quit S: +OK POP3 server signing off M2-Internet 81

POP3 (more) and IMAP More about POP3 Previous example uses download and delete mode. Bob cannot re-read e- mail if he changes client Download-and-keep : copies of messages on different clients POP3 is stateless across sessions IMAP Keep all messages in one place: the server Allows user to organize messages in folders IMAP keeps user state across sessions: names of folders and mappings between message IDs and folder name M2-Internet 82