Comment Ca Marche - Communauté informatique  
   
Accueil - Encyclopédie informatiqueTélécharger l'encyclopédieContribuer à cet article

ASP - Le fichier global.asa

ASP - Le fichier global.asa Encyclopédie


Introduction au fichier global.asa

Afin de permettre de configurer une application (un site web) avec des paramètres par défaut sans devoir modifier la configuration du serveur, le modèle ASP propose l'utilisation d'un fichier de configuration, nommé global.asa, qui, placé à la racine du site web, permet à son concepteur d'exécuter des instructions, d'initialiser des variables, avant ou après l'exécution d'un script.

Lorsque le fichier global.asa est modifié alors que le site est en production, le serveur attendra la fin des requêtes en cours avant de prendre en compte les modifications ! Il est ainsi probable de voir le serveur HTTP renvoyer des messages d'erreurs durant le temps de redémarrage de l'application nécessaire à la prise en compte de ces changements !

Le format du fichier global.asa

Le fichier global.asa est constitué de plusieurs sections optionnelles de 3 types. Les 3 types de sections sont les suivants :

  • une ou plusieurs sections <script>, permettant de gérer des événements liés aux objets Application et Session ;
  • une ou plusieurs sections <object>, permettant de créer ou de détruire des objets Application et/ou Session ;
  • une ou plusieurs sections de définition des bibliothèques de type.

Il est possible d'ajouter des commentaires dans le fichier global.asa en utilisant les balises de commentaire HTML :

<!-- Ceci est un commentaire HTML pouvant être inséré
dans le fichier global.asa -->

L'ordre dans lequel les sections sont définies n'a pas d'importance. De plus chaque section peut être ou non définie. Il peut également exister plusieurs sections de même type.

La section <script>

La section <script> permet de définir des événements liés aux objets Application et Session grâce à deux gestionnaires d'événements permettant de gérer deux états : le démarrage (OnStart) et l'expiration (OnEnd).

La section script permet ainsi de gérer quatre événements :

Evénement Description
Application_OnStart Il s'agit d'un événement déclenché au démarrage de l'application, c'est-à-dire à la mise en service du site web. Dans la mesure où aucun client n'est connecté au moment du lancement de l'application, il est impossible de faire appel au sein de cet événement aux objets Session, Request ou Response. L'appel à ces derniers provoque une erreur. Ainsi il est uniquement possible de faire appel aux objets Application et Server au sein de ce gestionnaire d'événement.
Application_OnEnd Ce gestionnaire d'événement sera appelé lors de la mise hors service de l'application (par exemple l'arrêt du serveur HTTP). De façon analogue au gestionnaire d'événement Application_OnStart, l'appel aux objets Session, Request ou Response provoque une erreur étant donné que ceux-ci ont été préalablement terminés. Seuls les objets Application et Server peuvent donc être utilisés au sein de cet événement.
Session_OnStart Cet événement est appelé au démarrage d'une session d'un utilisateur. Contrairement aux événements liés à l'objet Application, il est possible dans l'événement Session_OnStart de faire appel à tous les objets ASP (Request, Response, Session, Application, Server et ObjectContext).
Session_OnEnd L'événement Session_OnEnd est déclenché lors de la fermeture de la session par l'utilisateur, ou bien lorsque le temps alloué à la session est expiré. Ainsi, puisque cet événement peut être déclenché sans requête du client, seuls les objets Application, Session et Server peuvent être utilisés.

La section <Script> se construit de la manière suivante :

<SCRIPT LANGUAGE="VBScript" RUNAT="Server">

  Sub Application_OnStart
	'Code à placer éventuellement à cet emplacement
  End Sub
  Sub Application_OnEnd
	'Code à placer éventuellement à cet emplacement
  End Sub
  Sub Session_OnStart
	'Code à placer éventuellement à cet emplacement
  End Sub
  Sub Session_OnEnd
	 'Code à placer éventuellement à cet emplacement
  End Sub
</SCRIPT>

Voici un exemple d'utilisation du fichier global.asa servant à afficher sur le site le nombre de connectés simultanés. Sera considéré comme connecté tout utilisateur ayant fait une requête dans les 15 minutes précédentes.

<SCRIPT LANGUAGE="VBScript" RUNAT="Server">

  Sub Application_OnStart
	'Initialisation du nombre de connectés
	Application("nb_connectes") = 0
  End Sub
  Sub Application_OnEnd
	'Code à placer éventuellement à cet emplacement
  End Sub
  Sub Session_OnStart
		Session("debut") = now()
	Application.Lock
	Application("nb_connectes") = Application("nb_connectes") + 1
	Application.UnLock
  End Sub
  Sub Session_OnEnd
	 'Code à placer éventuellement à cet emplacement
	Application.Lock
	Application("nb_connectes") = Application("nb_connectes") - 1
	Application.UnLock
  End Sub
</SCRIPT>

Pour afficher le résultat dans la page ASP, il suffira d'inclure la ligne suivante :

<% Response.Write(Application("nb_connectes")) %>

La section <object>

La section Object du fichier global.asa a pour but de permettre de déclarer des objets pouvant ainsi être mis à disposition de tous les visiteurs (en lui donnant comme portée l'objet Application) ou bien de chaque visiteur séparément (en lui donnant comme portée l'objet Session).

Les objets déclarés dans la section object ne sont pas instanciés avant d'être appelés dans un script, ainsi la mémoire n'est pas nécessairement allouée si elle n'a pas de raison de l'être.

Voici la structure d'une section Object :

<Object 	RunAt="Server"
				Scope="Session|Application"
				Id="Identifiant"
				{ProgId="ProgId"|ClassId="ClassId"}>

</Object>

L'attribut RunAt doit obligatoirement être égal à Server. L'attribut Scope définit la portée de l'objet. Si la portée est Application, l'objet ainsi défini sera partagé par tous les utilisateurs de l'application, par contre s'il s'agit de Session, chaque utilisateur bénificiera d'une instance particulière. Enfin l'attribut Id définit un identifiant permettant de faire appel à l'objet au sein des scripts, ProgId et ClassId permettent de faire appel à des identifiants respectivement de classe et de classe COM d'objets existants. Suivant que l'on fait référence à un objet COM ou non on utilisera l'un ou l'autre de ces attributs.

Il est impératif de ne pas imbriquer les sections Object et les sections Script !

Voici un exemple comprenant deux déclarations d'objets :

<Object 	RunAt="Server"
	Scope="Application"
	Id="Application_id"
	ClassId="Clsid:5DC843A2F1-3FC3-5DE4-432B-5A5C5A9F89ED">

</Object>

<Object 	RunAt="Server"
	Scope="Session"
	Id="Connection_id"
	ProgId="ADODB.Connection">

</Object>

Plus d'information

Discussions pertinentes trouvées dans le forum

13/07 10h25 global.asa compteur visiteurs Global.asa & Compteur de visiteurs Développement 13/07 11h24->RiKé2
13/12 19h56 asp global asa initialisation ASP: Global asa - Prob initialisation Développement 16/12 15h55->A'Gain2
13/07 10h23 global.asa compteur visiteurs Global.asa, compteur de visiteurs Windows 14/07 10h22->mike1
25/01 13h40 global.asa Global.asa Windows 25/01 13h40->Houda0
09/01 13h57 asp global.asa po pb ASP Global.asa marche po ;-( Développement 09/01 13h57->JobMcLain0
11/08 18h52 global.asa Pb global.asa Développement 11/08 18h52->cigale0
27/10 16h16 response.redirect global.asa response.redirect dans le global.asa Développement 27/10 16h16->samira0
08/09 12h13 conflict global storm hébergement (conflict global storm) hébergement ? Jeux vidéos 29/01 22h16->Evan.dd2
06/12 05h56 problême variable global fonction problême avec variable global dans fonction Webmastering 06/12 07h45->vitessenet1
Discussion fermée Problème résolu Global.asa Plus de discussions sur « Global.asa »

Ce document intitulé « ASP - Le fichier global.asa » issu de l'encyclopédie informatique Comment Ça Marche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.