Global.asa 檔案是一個可選的檔案,它可包含可被 ASP 應用程式中每個頁面訪問的對象、變數以及方法的聲明。
Global.asa 檔案
Global.asa 檔案是一個可選的檔案,它可包含可被 ASP 應用程式中每個頁面訪問的對象、變數以及方法的聲明。所有合法的瀏覽器指令碼都能在 Global.asa 中使用。
Global.asa 檔案可包含下列內容:
Application 事件
Session 事件
<object> 聲明
TypeLibrary 聲明
#include 指令
注釋:Global.asa 檔案須存放於 ASP 應用程式的根目錄中,且每個應用程式只能有一個 Global.asa 檔案。
Global.asa 中的事件
在 Global.asa 中,我們可以告知 application 和 session 對象在啟動和結束時做什麼事情。完成這項任務的代碼被放置在事件操作器中。Global.asa 檔案能包含四種類型的事件:
Application_OnStart - 此事件會在首位使用者從 ASP 應用程式調用第一個頁面時發生。此事件會在 網頁伺服器重起或者 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 'some codeend subsub Application_OnEnd 'some codeend subsub Session_OnStart 'some codeend subsub Session_OnEnd 'some codeend sub</script>
注釋:由於無法使用 ASP 的指令碼分隔字元 (<% 和 %>) 在 Global.asa 檔案中插入指令碼,我們需使用 HTML 的 <script> 元素。
<object> 聲明
可通過使用 <object> 標籤在 Global.asa 檔案中建立帶有 session 或者 application 範圍的對象。
注釋:<object> 標籤應位於 <script> 標籤之外。
文法:
<object runat="server" scope="scope" id="id"{progid="progID"|classid="classID"}>....</object>
參數 描述
scope 設定對象的範圍(作用範圍)(Session 或者 Application)。
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 檔案中的任何位置(在 <script> 標籤的內外均可)。不過,我們還是推薦將 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_OnStartSession("started")=now()end sub</script>
Global.asa 也可用於控制頁面訪問。
下面的例子展示如何把每位新的訪問者重新導向到另一個頁面,在這個例子中會定向到 "newpage.asp" 這個頁面:
<script language="vbscript" runat="server">sub Session_OnStartResponse.Redirect("newpage.asp")end sub</script>
我們還可以在 Global.asa 中包含函數。
在下面的例子中,當 Web 服務器啟動時,Application_OnStart 子常式也會啟動。隨後,Application_OnStart 子常式會調用另一個名為 "getcustomers" 的子常式。"getcustomers" 子常式會開啟一個資料庫,然後從 "customers" 表中取回一個記錄集。此記錄集會賦值給一個數組,在不查詢資料庫的情況下,任何 ASP 頁面都能夠訪問這個數組:
<script language="vbscript" runat="server">sub Application_OnStartgetcustomersend subsub 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.GetRowsrs.Closeconn.Closeend 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_OnStartApplication("visitors")=0End SubSub 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免費視頻教程