Programmation web pour debutant concepts fondamontaux
Participez au vote ☆☆☆☆☆★★★★★
Les pages dynamiques et l’accès aux bases de données sont des technologies indispensables
au développement d’un site web. Les sites web utilisant les pages dynamiques et les bases de
données règnent aujourd’hui en maitre sur internet .Il n’est plus imaginable de développer un
site sans faire appel à ces technologies et aux possibilités et de personnalisation qu’elles
permettent. Ce chapitre présente et explique la notion de client/serveur et le concept du Web,
ainsi que les pages dynamiques.
II. PRESENTATION DE CLIENT /SERVEUR
Le mode client/serveur est un mode de fonctionnement dissymétrique dans lequel deux
logiciels différents sont nécessaire pour permettre les communications : un logiciel serveur et
un logiciel client, nécessaire sur toutes machines.[ Tout sur les systèmes d'information, Jean
François Pillou, Dunod 1996]
II.1.Définition
Un environnement client/serveur désigne un mode de communication à travers un réseau
informatique entre plusieurs logiciels.
Un logiciel client et un logiciel serveur sont reliés par un réseau informatique.
Le logiciel client peut envoyer une requête au logiciel serveur.
II.2. Le client serveur pour web
Dans le cas qui nous intéresse ;c’est-a-dire le web , le client est un navigateur de tels logiciels
existent pour tous les systèmes d’exploitation :
Les sites web sont héberges sur des serveurs dédies qui sont nommés serveurs web. A l’heure
actuelle ; le logiciel le plus répondu est APACHE http server ;et bien sur il existe d’autres
serveurs web.
Le navigateur émet une requête http vers un serveur web afin d’obtenir la page web désirée
.Le serveur envoie les données demandées par le client ; si celui –ci est autorisé à accéder au
document .Le navigateur interprète les instructions de mise en page contenus dans les données
envoyées par le serveur.
1
Chapitre I Concept fondamentaux du web
II.3. Fonctionnement d’un système client/serveur
Un system client /serveur fonctionne selon le schéma suivant :
Figure I .1: Fonctionnement de system client /serveur
Le client émet une requête vers le serveur grâce à son adresse IP et le port ; qui désigne un
service particulier du serveur.
Le serveur reçoit la demande et répond à l’aide de l’adresse de la machine client et son port
II.4. L’architecteur system client/serveur
De nombreuses applications fonctionnent selon un environnement client/serveur. Cela signifie
que des machines clients (des machines faisans partie du réseau) contactent un serveur, une
machine généralement très puissante en terme de capacité d’entrée-sortie, qui leur fournit des
services .Ces services sont des programmes fournissant des données t’elle que l’heure ; des
fichiers, une connexion, etc.
Les services sont exploités par des programmes, appelés programmes client, s’exécutant sur
les machines clients .On parle ainsi de client (client FTP, client de messagerie, etc.) lorsque
l’on désigne un programme tournants sur une machine cliente, capable de traiter des
informations qu’il récupère auprès du serveur (dans le cas du client FTP il s’agit de fichier ;
tandis que pour le client de messagerie il s’agit de courrier électronique).
II.4.1. Présentation de l’architecteur à 2 niveaux
L'architecture à deux niveaux (aussi appelée architecture 2-tier, tier signifiant rangée en
anglais) caractérise les systèmes clients/serveurs pour lesquels le client demande une
ressource et le serveur la lui fournit directement, en utilisant ses propres ressources. Cela
signifie que le serveur ne fait pas appel à une autre application afin de fournir une partie du
service.
2
Chapitre I Concept fondamentaux du web
Figure I.2 l’architecteur à 2 niveaux
II.4.2. Présentation de l’architecteur à 3 niveaux
Dans l'architecture à 3 niveaux (appelée architecture 3-tier), il existe un niveau intermédiaire,
c'est-à-dire que l'on a généralement une architecture partagée entre :
Un client, c'est-à-dire l'ordinateur demandeur des ressources , équipée d'une interface
utilisateur (généralement un navigateur web) chargée de la présentation ;
Le serveur d'application (appelé également middleware), chargé de fournir la ressource mais
faisant appel à un autre serveur
Le serveur des données, fournissant au serveur d'application les données dont il a besoin.
Figure I.3 l’architecteur à 3 niveaux
Etant donné l'emploi massif du terme d'architecture à 3 niveaux, celui-ci peut parfois désigner
aussi les architectures suivantes :
Partage l'application entre client, serveur intermédiaire, et serveur d'entreprise ;
Partage l'application entre client, serveur d'application, et serveur de données d'entreprise.
3
Chapitre I Concept fondamentaux du web
II.4.3. Présentation de l’architecteur à N niveaux
L'architecture 3 niveaux permet de spécialiser les serveurs dans une tache précise : avantage
de flexibilité, de sécurité et de performance. L'architecture peut être étendue sur un nombre de
niveaux plus important : on parle dans ce cas d'architecture à N niveaux (ou multi-tier).
Figure 1_2 l’architecteur à N niveaux
II.5. Avantages de l'architecture client-serveur
? Des ressources centralisées : Toutes les données sont centralisées sur un seul serveur, ce
qui simplifie les contrôles de sécurité, l'administration, la mise à jour des données et des
logiciels.
Les technologies supportant l'architecture client-serveur sont plus matures que les autres.
La complexité du traitement et la puissance de calculs sont à la charge d’ ou des serveurs, les
utilisateurs utilisant simplement un client léger sur un ordinateur terminal qui peut être
simplifié au maximum.
?: les serveurs étant centralisés, cette architecture est
particulièrement adaptée et véloce pour retrouver et comparer de vaste quantité d'informations
(moteur de recherche sur le Web), ce qui semble être rédhibitoire pour le P2P beaucoup plus
lent, à l'image de Free net.
II.6. Inconvénients de l'architecture client-serveur
Si trop des clients veulent communiquer avec le serveur au même moment, ce dernier risque
de ne pas supporter la charge (alors que les réseaux pair-à-pair fonctionnent mieux en ajoutant
de nouveaux participants).
4
Chapitre I Concept fondamentaux du web
Si le serveur n'est plus disponible, plus aucun des clients ne fonctionne (le réseau pair-à-pair
continue à fonctionner, même si plusieurs participants quittent le réseau).
Les coûts de mise en place et de maintenance peuvent être élevés.
En aucun cas les clients ne peuvent communiquer entre eux, entrainant une asymétrie de
l'information au profit des serveurs.
III. PRESENTATION DU WEB
Le World Wide est Web est rapidement devenu le service le plus utilisé sur l'Internet. Il a
conçu le Hypertext Markup Language (HTML) à partir d'un autre format utilisé pour les
documents appelé le SGML. Le WWW fonctionne en utilisant le concept d'hypertexte. À
l'intérieur d'une page, il y a des mots clés ou des images qui ont des liens qui, lorsque vous
cliquez dessus, vous amènent à une autre page Web.
III.1. Historique d’Internet
L'Internet est un système de communication qui permet aux ordinateurs autour du monde de
communiquer et de s'échanger de l'information entre eux.
Internet est né en 1969 sous l'impulsion du département américain de la défense (DOD).
Le réseau, qui s'appelait alors ARPANET, devait assurer les échanges d'informations
électroniques entre les centres névralgiques américains dans le contexte de la guerre froide.
Le cahier de charge établi par le DOD imposait que le réseau puisse poursuivre ses activités
en cas d'attaque nucléaire soviétique.
Si l'un ou plusieurs des sites et lignes de connexion venait à être détruit, les messages
parviendraient à leur destinataire par des itinéraires alternatifs.
Un grand nombre de centres de recherche, militaires, publics et privés prirent part à ce projet.
Il était normal que leurs réseaux internes furent les premiers reliés à Internet.
C'est pourquoi, dès sa création, Internet sera un méta-réseau, un réseau de réseaux qui va peu
à peu relier la communauté scientifique et universitaire mondiale
Internet arrive en Europe en 1982.
L'année 1984 est une année charnière: Internet perd son caractère militaire.
5
Chapitre I Concept fondamentaux du web
Son financement n'est plus assuré par le DARPA mais par un organisme scientifique civil créé
deux ans plus tard :
La National Science Foundation (NSF).
Le réseau est scindé en deux parties: MILnet, réseau strictement militaire et NSFnet, le
backbone ou épine dorsale d'Internet.
Sa facilité d'utilisation contribue grandement à d'populariser les autoroutes de l'information
World Wide Web apparaît l'année suivante.
Depuis la chute du mur de Berlin en 1989, Internet s'est largement ouvert au grand public et à
l'exploitation commerciale.
III.2. le WEB
Dans les années 90, un nouveau service de l'Internet est apparu : le World Wide Web, la toile
d'araignée mondiale, encore désignée par l'acronyme WWW ou le diminutif Web. C'est ce
service qui assure un certain succès à l'Internet. L'idée est de lire des hyperdocuments à l'aide
d'un navigateur.
Un hyperdocument est un document électronique contenant des images, du son, du texte,
parfois des petits morceaux de programme, mais surtout des liens vers d'autres
hyperdocuments : des liens hypertextes. Ces liens apparaissent dans un style qui les
distinguent, et une simple action de la souris sur un lien suffit à ouvrir le document lié. Les
documents peuvent se trouver sur n'importe quelle machine (serveur) de l'Internet à des
endroits parfois très éloignés et c'est ce qui donne l'impression à l'utilisateur de naviguer sur le
réseau.
Le navigateur est l'outil qui permet de lire les hyper documents. On l'appelle aussi browser et
les deux plus connus aujourd'hui sont MicroSoft Internet Explorer (MSIE) et Netscape. Au
début conçu pour ne lire que les hyper documents, le navigateur intègre aujourd'hui tous les
services de l'Internet (e-mail, ftp, )
Le navigateur désigne par une adresse URL (Uniform Resource Locator), les adresses
complètes de l'Internet. C'est une adresse qui contient à la fois le nom d'une machine mais
aussi le nom du service demandé, le nom d'un document,
6
Chapitre I Concept fondamentaux du web
Un autre standard incontournable de l'Internet est HTML (HyperText Markup Language).
C'est le langage qui permet d'écrire des hyperdocuments de façon descriptive à l'aide de
marqueurs.
III.3. Standards du web
Le web repose trois standards : les URL ,http ET HTML , hypertext
III.3.1. URL
Une URL(Uniform Resource Locator) est une simple ligne de texte qui permet de retrouver
une ressource (texte, image, musique, vidéo, programme )sur internet . Il s'agit d'une chaîne
de
caractères ASCII
imprimables
qui
se
décompose
en
cinq
parties:
? Le nom du : c'est-à-dire en quelque sorte le langage utilisé pour communiquer
sur le réseau. Le protocole le plus largement utilisé est le protocole HTTP (HyperText
Transfer Protocol), le protocole permettant d'échanger des pages Web au format HTML. De
nombreux autres protocoles sont toutefois utilisables (FTP, News,Mailto,Gopher, )
? Identifiant et mot de passe : permet de spécifier les paramètres d'accès à un serveur
sécurisé. Cette option est déconseillée car le mot de passe est visible dans l'URL
? Le nom du : Il s'agit d'un nom de domaine de l'ordinateur hébergeant la ressource
demandée. Notez qu'il est possible d'utiliser l'adresse IP du serveur, ce qui rend par contre
l'URL moins lisible.
? Le numéro de : il s'agit d'un numéro associé à un service permettant au serveur de
savoir quel type de ressource est demandée. Le port associé par défaut au protocole est le port
numéro 80. Ainsi, lorsque le service Web du serveur est associé au numéro de port 80, le
numéro de port est facultatif
? Le chemin d'accès à la ressource : Cette dernière partie permet au serveur de connaître
l'emplacement auquel la ressource est située, c'est-à-dire de manière générale l'emplacement
(répertoire) et le nom du fichier demandé
Une URL a donc la structure suivante :
Protocole Mot de passe (facultatif) Nom du serveur
Port(facultatifsi 80)
Chemin
http://
user:password@
:80
/glossair/glossair.php3
7
Chapitre I Concept fondamentaux du web
III.3.2. Protocole http
L'HTTP (Hypertext Transfer Protocol) est le protocole de transport utilisé par les navigateurs
Web (Firefox, Internet Explorer ) et les serveurs Web (Apache, IIS ) pour communiquer
entre eux. C'est lui qui est utilisé par exemple pour obtenir un fichier HTML, une image,
poster un formulaire Internet. Il est donc au cœur de l'Internet. Techniquement c'est un
protocole texte (donc lisible en clair) s'appuyant les protocoles plus bas-niveau TCP/ IP.
Avec HTTP la communication entre un navigateur et un serveur Web est finalement assez
simple. En voici le déroulé :
Une URL telle que est donnée au Navigateur par un
internaute.
Le navigateur en extrait le nom de domaine '' et à partir de cette
information sait comment trouver le serveur Web distant (grâce à
une opération dite de DNS look up qui résout un nom de domaine en une adresse IP) ,à partir
de là une connexion (basée sur les protocoles TCP/IP) est établie entre le navigateur et le
serveur Web distant .
Une requête HTTP demandant la ressource '' est alors transmise par le navigateur,
le serveur Web trouve la ressource correspondante et en renvoie le contenu dans une réponse
http, le navigateur est désormais capable d'afficher le fichier HTML à l'internaute
III.3.3. Pages web dynamique
Le principe d'un page dynamique est d'être construite à la demande (à la volée) par le
serveur (côté serveur), en fonction de critères spécifiques. La présentation et le contenu
affichés peuvent ainsi être personnalisés de manière interactive, en fonction des produits, des
internautes, des langues, etc.
On reconnaît facilement un page dynamique grâce à l'URL qui s'affiche dans le navigateur
web de l'utilisateur:
? Page statique: affiche la page , stockée telle quelle sur le serveur,
? Page dynamique: affiche la page en demandant au serveur d'afficher le
contenu de cette page en français.
8
Chapitre I Concept fondamentaux du web
Alors que les pages statiques font appel au html, langage de description de données, les pages
dynamiques sont mises en œuvre grâce à un langage de programmation. Grâce à lui, on
pourra disposer d'instructions conditionnelles, des boucles et des fonctions de traitement
complexes. Le langage de programmation variera en fonction de la technologie retenue (PHP,
ASP, Java, etc.).
III.3.4. Hypertexte
Le système hypertext est un système contenant des nœuds liés entre eux par des hypertexte est
donc un document qui contient des hyperliens et des nœuds .Un nœuds est « une unité
minimale d’information » , notion assez floue qui signifie simplement que l’information d’un
nœud sera toujours présentée entière
Lorsque les nœuds ne sont pas uniquement textuels ; mais aussi audiovisuels ;on peut parler
de système et de document hypermedias.
III.4. Les technologies dynamique du coté serveur
Le serveur web est un ensemble ordinateur/logiciel paramétré pour pouvoir traiter certains
types de pages et notamment celles qui contiennent des instructions de programmation. Il
reconnaît ces pages grâce à l'URL qu'il reçoit, effectue les traitements demandés et transmet le
résultat au format html au browser de l'internaute.
III.4.1. Active server pages(ASP)
Active Server Pages (ASP) est un ensemble des logiciels développés par Microsoft et utilisés
dans la programmation Web.
C'est une suite des logiciels destinées à créer des sites web dynamiques. Elle nécessite pour
fonctionner une plate-forme Windows avec IIS installé, ou encore une plate-forme Linux ou
Unix avec une version modifiée d'Apache. ASP est une structure composée d'objets
accessibles par deux langages principaux : le VBScript et le JScript. Il est possible d'utiliser
d'autres langages comme le PerlScript, le REXX, ou encore le Python en ajoutant le moteur
d'interprétation du langage adéquat à IIS.
À l'inverse de certains langages de programmation (C, C++), cette technologie n'utilise pas de
langages compilés, mais des langages interprétés.
9
Chapitre I Concept fondamentaux du web
III.4.2. Java Server Pages(JSP)
Le Java Server Pages ou JSP est une technique basée sur Java qui permet aux développeurs de
créer dynamiquement du code HTML, XML ou tout autre type de page web. Cette technique
permet au code Java et à certaines actions prédéfinies d'être ajoutés dans un contenu statique.
Il s’agit en réalité d’un langage de script puissant exécuté du coté du serveur (au même titre
que les scripts CGI,PHP,ASP ..) et non du coté client.
III.4.3. Comun Gateway Interface(CGI)
Un script CGI (interface de passerelle commune) est un programme exécuté par le serveur
web (on dit généralement « côté serveur »), permettant d'envoyer au navigateur de l'internaute
un code HTML créé automatiquement par le serveur.
Un des principaux intérêts de l'utilisation de CGI est la possibilité de fournir des pages
dynamiques, c'est-à-dire des pages personnalisées selon un choix ou une saisie de l'utilisateur.
L'application la plus fréquente de cette technique repose sur l'utilisation de formulaires
HTML permettant à l'utilisateur de choisir ou de saisir des données, puis de cliquer sur un
bouton de soumission du formulaire, envoyant alors les données du formulaire en paramètre
du script CGI.
III.4.4. PHP
PHP est un langage de programmation informatique essentiellement utilisé pour produire à la
volée des pages web dynamiques, PHP s’est imposé comme le langage de référence sur le
web en raison de sa simplicité, de sa gratuité et de son origine de logiciel libre.
Il très puissant, rapide et principalement exécuté par le compilateur PHP.
Un script PHP est multiplateforme, très bon support des bases de données (Oracle, Microsoft,
MySQL).
III.4.5. MYSQL
MySQL (My Structured Query Language) est un Système de Gestion des Bases des données
(SGBD) Open Source très rapide, robuste et multiutilisateur. Le serveur MySQL supporte le
langage de requêtes SQL, langage standard de choix des SGBD modernes. Il est facilement
accessible en réseaux et supporte des connexions sécurisées grâce au protocole SSL. La
portabilité du serveur MySQL lui permet de s'exécuter sur toutes les plateformes et d'être
intégré à plusieurs serveurs web.
10
Chapitre I Concept fondamentaux du web
IV. CONCLUSION
Dans ce chapitre nous avons présenté l’Internet et le Web sont deux concepts à tel
point liée que la confusion règne parfois chez les nouveaux utilisateurs. L’Internet
a pris l’ampleur et relie aujourd’hui plusieurs millions de machines fonctionnent
sur une architecture client-serveur qui doit utiliser le même protocole de
communication TCP/IP.
Le chapitre suivant présente la technologie utilisée au sein de ce projet et ses
intérêts.
11