>  기사  >  백엔드 개발  >  ASP의 Global.asa 파일에 대한 자세한 소개

ASP의 Global.asa 파일에 대한 자세한 소개

Y2J
Y2J원래의
2017-05-19 10:55:301432검색

Global.asa 파일은 ASP 응용 프로그램의 모든 페이지에서 액세스할 수 있는 개체, 변수 및 메서드 선언이 포함된 선택적 파일입니다.

Global.asa 파일

Global.asa 파일은 개체, 변수 및 메서드 선언이 포함된 선택적 파일입니다. 모든 합법적인 브라우저 스크립트는 Global.asa에서 사용할 수 있습니다.

Global.asa 파일에는 다음이 포함될 수 있습니다.

애플리케이션 이벤트

세션 이벤트

273238ce9338fbb04bee6997e5552b95 >

TypeLibrary 선언

#include 지시문

참고: Global.asa 파일은 ASP 응용 프로그램의 루트 디렉터리에 저장되어야 하며 각 응용 프로그램에는 Global.asa가 하나만 있을 수 있습니다. 문서.

Global.asa의 이벤트

Global.asa에서는 시작과 종료 시 수행할 작업을 애플리케이션과 세션 개체에 알려줄 수 있습니다. 이 작업을 수행하는 코드는 이벤트 연산자에 배치됩니다. Global.asa 파일에는 네 가지 유형의 이벤트가 포함될 수 있습니다.

Application_OnStart - 이 이벤트는 첫 번째 사용자가 ASP 응용 프로그램에서 첫 번째 페이지를 호출할 때 발생합니다. 이 이벤트는 웹 서버가 다시 시작되거나 Global.asa 파일이 편집된 후에 발생합니다. "Session_OnStart" 이벤트는 이 이벤트 직후에 발생합니다.

Session_OnStart - 이 이벤트는 새 사용자가 ASP 애플리케이션에서 첫 번째 페이지를 요청할 때마다 발생합니다.

Session_OnEnd - 이 이벤트는 사용자가 세션을 종료할 때마다 발생합니다. 지정된 시간(기본 이벤트는 20분) 내에 페이지가 요청되지 않으면 세션이 종료됩니다.

Application_OnEnd - 이 이벤트는 마지막 사용자가 세션을 종료한 후에 발생합니다. 일반적으로 이 이벤트는 웹 서버가 중지될 때 발생합니다. 이 서브루틴은 애플리케이션이 중지된 후 기록 삭제, 텍스트 파일에 정보 쓰기 등의 설정을 지우는 데 사용됩니다.

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>

참고: Global.asa에서는 ASP 스크립트 구분 기호(4550026a6dbf3b766c4c99300b0e64a1)를 사용할 수 없으므로 파일에 스크립트를 삽입하려면 HTML 3f1c4e4b6b16bbbd69b2ee476dc4f83a 요소를 사용해야 합니다.

273238ce9338fbb04bee6997e5552b95

선언은 273238ce9338fbb04bee6997e5552b95 태그를 사용하여 Global.asa 파일에 세션 또는 애플리케이션 범위의 객체를 생성할 수 있습니다.

참고: 273238ce9338fbb04bee6997e5552b95 태그는 3f1c4e4b6b16bbbd69b2ee476dc4f83a 태그 외부에 있어야 합니다.

구문:

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

매개변수                                                                           ~

id 개체의 고유 ID를 지정합니다.

ProgID ClassID와 연결된 ID입니다. ProgID의 형식은 [Vendor.]Component[.Version]입니다. ProgID 또는 ClassID를 지정해야 합니다.

ClassID COM 클래스 개체의 고유 ID를 지정합니다. ProgID 또는 ClassID를 지정해야 합니다.

인스턴스

첫 번째 인스턴스는 ProgID 매개변수를 사용하여 "MyAd"라는 세션 범위 개체를 생성합니다.

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

두 번째 인스턴스 인스턴스가 생성됩니다. ClassID 매개변수를 사용하여 "MyConnection"이라는 이름의

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

매개변수 설명

파일은 유형 라이브러리의 절대 경로를 지정합니다. 매개변수 파일이나 uuid 둘 다 필수입니다.

uuid는 유형 라이브러리의 고유 식별자를 지정합니다. 매개변수 파일이나 uuid 둘 다 필수입니다.

버전 선택사항. 버전을 선택하는데 사용됩니다. 지정된 버전이 없으면 가장 가까운 버전이 사용됩니다.

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으로 문의하세요.