首頁 >後端開發 >C#.Net教程 >關於ASP中Global.asa檔案的詳細介紹

關於ASP中Global.asa檔案的詳細介紹

Y2J
Y2J原創
2017-05-19 10:55:301549瀏覽

Global.asa 檔案是一個可選的文件,它可包含可被 ASP 應用程式中每個頁面存取的物件、變數以及方法的宣告。

Global.asa 文件

Global.asa 檔案是一個可選的文件,它可包含可被ASP 應用程式中每個頁面存取的物件、變數以及方法的宣告。所有合法的瀏覽器腳本都能在 Global.asa 中使用。

Global.asa 檔案可包含下列內容:

Application 事件

Session 事件

273238ce9338fbb04bee6997e5552b95 宣告

TypeLibrary 宣告

#include 指令

註解:Global.asa 檔案須存放於ASP 應用程式的根目錄中,且每個應用程式只能有一個Global.asa文件。

Global.asa 中的事件

在 Global.asa 中,我們可以告知 application 和 session 物件在啟動和結束時做什麼事情。完成這項任務的程式碼被放置在事件操作器中。 Global.asa 檔案可包含四種類型的事件:

Application_OnStart - 此事件會在第一位使用者從 ASP 應用程式呼叫第一個頁面時發生。此事件會在 web 伺服器重起或 Global.asa 檔案被編輯之後發生。 "Session_OnStart" 事件會在此事件發生後立即發生。

Session_OnStart - 此事件會在每當新使用者請求他或她的在 ASP 應用程式中的首個頁面時發生。

Session_OnEnd - 此事件會在每當使用者結束 session 時發生。在規定的時間(預設的事件為 20 分鐘)內如果沒有頁面被請求,session 就會結束。

Application_OnEnd - 此事件會在最後一位使用者結束其 session 之後發生。典型的情況是,此事件會在 Web 伺服器停止時發生。此子程式用於在應用程式停止後清除設置,例如刪除記錄或向文字檔案寫入資訊。

Global.asa 檔案可能類似這樣:

<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>

註解:由於無法使用ASP 的腳本分隔符號(922421d9b7bee4ab53064de062cc676c) 在Global.asa文件中插入腳本,我們需使用HTML 的3f1c4e4b6b16bbbd69b2ee476dc4f83a 元素。

273238ce9338fbb04bee6997e5552b95 宣告

可透過使用 273238ce9338fbb04bee6997e5552b95 標籤在 Global.asa 檔案中建立帶有 session 或 application 作用域的物件。

註解:273238ce9338fbb04bee6997e5552b95 標籤應位於 3f1c4e4b6b16bbbd69b2ee476dc4f83a 標籤之外。

語法:

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

參數                描述上

scope              

id ​​                為物件指定一個獨特的 id。    

ProgID          與 ClassID 相關的 id。 ProgID 的格式是:[Vendor.]Component[.Version]。 ProgID 或 ClassID 必需被指定。

ClassID          為 COM 類別物件指定唯一的 id。 ProgID 或 ClassID 必要被指定。

實例

第一個實例建立了一個名為"MyAd" 且使用ProgID 參數的session 作用域物件:

<object runat="server" scope="session" id="MyAd" progid="MSWC.AdRotator">
</object>

第二個實例建立了名為"MyConnection" 且使用ClassID 參數的

<object runat="server" scope="application" id="MyConnection"classid="Clsid:8AD3067A-B3FC-11CF-A560-00A0C9081C21">
</object>

在此Global.asa 檔案中聲明的這些物件可被應用程式中的任何腳本使用。

GLOBAL.ASA:

<object runat="server" scope="session" id="MyAd" progid="MSWC.AdRotator">
</object>

您可以從ASP 應用程式中的任意頁面引用此"MyAd" 物件:

某個.ASP 檔案:

<%=MyAd.GetAdvertisement("/banners/adrot.txt")%>

TypeLibrary 宣告

TypeLibrary (類型庫)是一個容器,其中裝有對應於COM 物件的DLL 檔案。透過在 Global.asa 中包含對 TypeLibrary 的調用,可以存取 COM 物件的常數,同時 ASP 程式碼也能更好地報告錯誤。假如您的網站的應用程式依賴已在類型庫中聲明過資料類型的 COM 對象,您可以在 Global.asa 中對類型庫進行聲明。

語法:

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

參數            說明

file            規定指向類型庫中的絕對路徑。參數 file 或 uuid,兩者缺一不可。    

uuid          規定了針對型別函式庫的唯一的識別碼。參數 file 或 uuid,兩者缺一不可。    

version     可選。用於選擇版本。假如沒有找到指定的版本,將使用最接近的版本。    

lcid           可選。用於類型庫的地區標識符。    

錯誤值

伺服器會傳回以下的錯誤訊息之一:

错误        代码        描述

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免费视频教程

以上是關於ASP中Global.asa檔案的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn