Maison  >  Article  >  développement back-end  >  Introduction détaillée au fichier Global.asa dans ASP

Introduction détaillée au fichier Global.asa dans ASP

Y2J
Y2Joriginal
2017-05-19 10:55:301432parcourir

Le fichier Global.asa est un fichier facultatif qui contient des déclarations d'objets, de variables et de méthodes accessibles par chaque page d'une application ASP.

Fichier Global.asa

Le fichier Global.asa est un fichier facultatif qui contient la déclaration des objets, des variables et des méthodes. Tous les scripts de navigateur légaux peuvent être utilisés dans Global.asa.

Le fichier Global.asa peut contenir les éléments suivants :

Événement d'application

Événement de session

403055ea185d4549c4138feab671e471 >

Déclaration TypeLibrary

Directive #include

Remarque : Le fichier Global.asa doit être stocké dans le répertoire racine de l'application ASP, et chaque application ne peut avoir qu'un seul Global.asa document.

Événements dans Global.asa

Dans Global.asa, nous pouvons indiquer à l'application et aux objets de session quoi faire au démarrage et à la fin. Le code pour accomplir cette tâche est placé dans l'opérateur d'événement. Le fichier Global.asa peut contenir quatre types d'événements :

Application_OnStart - Cet événement se produit lorsque le premier utilisateur appelle la première page depuis une application ASP. Cet événement se produit après le redémarrage du serveur Web ou la modification du fichier Global.asa. L'événement "Session_OnStart" se produit immédiatement après cet événement.

Session_OnStart - Cet événement se produit chaque fois qu'un nouvel utilisateur demande sa première page dans une application ASP.

Session_OnEnd - Cet événement se produit chaque fois que l'utilisateur termine la session. Si aucune page n'est demandée dans le délai spécifié (l'événement par défaut est de 20 minutes), la session se terminera.

Application_OnEnd - Cet événement se produit après que le dernier utilisateur ait terminé sa session. Généralement, cet événement se produit lorsque le serveur Web est arrêté. Ce sous-programme est utilisé pour effacer les paramètres après l'arrêt de l'application, tels que la suppression d'enregistrements ou l'écriture d'informations dans un fichier texte.

Le fichier Global.asa peut ressembler à ceci :

<script language="vbscript" runat="server">
sub Application_OnStart
  &#39;some code
end sub
sub Application_OnEnd
  &#39;some code
end sub
sub Session_OnStart
  &#39;some code
end sub
sub Session_OnEnd
  &#39;some code
end sub
</script>
Remarque : étant donné que les délimiteurs de script ASP (28bcf2047c89371241fb5d13477c798a) ne peuvent pas être utilisés dans Global Pour insérer un script dans un fichier .asa, nous devons utiliser l'élément HTML 3f1c4e4b6b16bbbd69b2ee476dc4f83a

273238ce9338fbb04bee6997e5552b95 La déclaration

peut créer un objet avec une portée de session ou d'application dans le fichier Global.asa en utilisant la balise 273238ce9338fbb04bee6997e5552b95

Remarque : La balise 273238ce9338fbb04bee6997e5552b95 doit être en dehors de la balise 3f1c4e4b6b16bbbd69b2ee476dc4f83a

Syntaxe :

<object runat="server" scope="scope" id="id"
{progid="progID"|classid="classID"}>
....
</object>
Paramètre Description

scope Définir la portée (portée) de l'objet (Session ou Application).

id Spécifiez un identifiant unique pour l'objet.

ProgID L'identifiant associé à ClassID. Le format de ProgID est : [Vendor.]Component[.Version]. ProgID ou ClassID doit être spécifié.

ClassID Spécifie un identifiant unique pour un objet de classe COM. ProgID ou ClassID doit être spécifié.

Instances

La première instance crée un objet de portée de session nommé "MyAd" à l'aide du paramètre ProgID :

<object runat="server" scope="session" id="MyAd" progid="MSWC.AdRotator">
</object>
La deuxième instance crée un

<object runat="server" scope="application" id="MyConnection"classid="Clsid:8AD3067A-B3FC-11CF-A560-00A0C9081C21">
</object>
nommé "MyConnection" à l'aide du paramètre ClassID Ces objets déclarés dans ce fichier Global.asa peuvent être utilisés par n'importe quel script de l'application.

GLOBAL.ASA :

<object runat="server" scope="session" id="MyAd" progid="MSWC.AdRotator">
</object>
Vous pouvez référencer cet objet "MyAd" depuis n'importe quelle page de votre application ASP :

Un fichier .ASP :

<%=MyAd.GetAdvertisement("/banners/adrot.txt")%>
Déclaration TypeLibrary

TypeLibrary (bibliothèque de types) est un conteneur qui contient des fichiers DLL correspondant aux objets COM. En incluant un appel à TypeLibrary dans Global.asa, vous pouvez accéder aux constantes de l'objet COM et votre code ASP peut mieux signaler les erreurs. Si les applications de votre site dépendent d'objets COM dont les types de données ont été déclarés dans une bibliothèque de types, vous pouvez déclarer la bibliothèque de types dans Global.asa.

Syntaxe :

<!--METADATA TYPE="TypeLib"
file="filename"
uuid="typelibraryuuid"
version="versionnumber"
lcid="localeid"
-->
Paramètre Description

file Spécifie le chemin absolu de la bibliothèque de types. Fichier de paramètres ou uuid, les deux sont indispensables.

uuid spécifie l'identifiant unique de la bibliothèque de types. Fichier de paramètres ou uuid, les deux sont indispensables.

version Facultative. Utilisé pour sélectionner la version. Si la version spécifiée n'est pas trouvée, la version la plus proche sera utilisée.

lcid Facultatif. L'identifiant de paramètres régionaux utilisé pour la bibliothèque de types.

Valeur d'erreur

Le serveur renverra l'un des messages d'erreur suivants :

错误        代码        描述

ASP        0222        Invalid type library specification    

ASP        0223        Type library not found    

ASP        0224        Type library cannot be loaded    

ASP        0225        Type library cannot be wrapped    

注释:METADATA 标签可位于 Global.asa 文件中的任何位置(在 3f1c4e4b6b16bbbd69b2ee476dc4f83a 标签的内外均可)。不过,我们还是推荐将 METADATA 标签放置于 Global.asa 文件的顶部。

限定

关于可以在 Global.asa 文件中引用的内容的限定:

你无法显示 Global.asa 文件中的文本。此文件无法显示信息。

你只能在 Application_OnStart 和 Application_OnEnd 子例程中使用 Server 和 Application 对象。在 Session_OnEnd 子例程中,你可以使用 Server、Application 和 Session 对象。在 Session_OnStart 子例程中,你可使用任何内建的对象。

如何使用子例程

Global.asa 常用于对变量进行初始化。

下面的例子展示如何检测访问者首次到达站点的确切时间。时间存储在名为 "started" 的 Session 对象中,并且 "started" 变量的值可被应用程序中的任何 ASP 页面访问:

<script language="vbscript" runat="server">
sub Session_OnStart
Session("started")=now()
end sub
</script>

Global.asa 也可用于控制页面访问。

下面的例子展示如何把每位新的访问者重定向到另一个页面,在这个例子中会定向到 "newpage.asp" 这个页面:

<script language="vbscript" runat="server">
sub Session_OnStart
Response.Redirect("newpage.asp")
end sub
</script>

我们还可以在 Global.asa 中包含函数。

在下面的例子中,当 Web 服务器启动时,Application_OnStart 子例程也会启动。随后,Application_OnStart 子例程会调用另一个名为 "getcustomers" 的子例程。"getcustomers" 子例程会打开一个数据库,然后从 "customers" 表中取回一个记录集。此记录集会赋值给一个数组,在不查询数据库的情况下,任何 ASP 页面都能够访问这个数组:

<script language="vbscript" runat="server">
sub Application_OnStart
getcustomers
end sub
sub getcustomers 
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open "c:/webdata/northwind.mdb"
set rs=conn.execute("select name from customers")
Application("customers")=rs.GetRows
rs.Close
conn.Close
end sub
</script>

Global.asa 实例

在这个例子中,我们要创建一个可计算当前访客的 Global.asa 文件。

Application_OnStart 设置当服务器启动时,Application 变量 "visitors" 的值为 0。

每当有新用户访问时,Session_OnStart 子例程就会给变量 "visitors" 加 1。

每当 Session_OnEnd 子例程被触发时,此子例程就会从变量 "visitors" 减 1。

Global.asa 文件:

<script language="vbscript" runat="server">
Sub Application_OnStart
Application("visitors")=0
End Sub
Sub Session_OnStartApplication.LockApplication("visitors")=Application("visitors")+1Application.UnLockEnd SubSub Session_OnEndApplication.LockApplication("visitors")=Application("visitors")-1Application.UnLockEnd Sub</script>
此 ASP 文件会显示当

前用户的数目:

<html>
<head>
</head>
<body>
<p>There are <%response.write(Application("visitors"))%> online now!</p>
</body>
</html>

【相关推荐】

ASP免费视频教程

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn