正确使用global.asa是asp开发者的一个共同问题。最主要的是要知道什么时候该用virtual application,什么时候该用virtual directory,并且知道他们的不同。
virtual directories(虚拟目录)
简而言之,virtual directories是虚拟出来的,不一定跟web root在同一个的目录上,可以是其他的。但是你可以像使用web root上的其他目录一样使用它。当运行global.asa以后,asp就把所有的虚拟目录看成是应用程序根目录上的子目录。
值得注意,如果你的目录已经是website root上的一个物理目录,那就没有必要再去为那个目录做虚拟目录了。当然,你有也可以这样做。如果你的目录的路径实在是太长,长到你无法忍受,想它短一点。你可以用建虚拟目录的方法。使它短些,容易记住。例如:原来的目录http://mysite.com/directory1/directory 2/file.asp,你可以为它建一个虚拟的目录,http://mysite.com/directory2/file.asp。这样就方便多了了。
virtual applications(虚拟应用程序)
virtual applications 是一个独立于website的web applications,而它跟virtual directories一样,不一定是web root上的一个目录。可以是从其他的目录虚拟出来的。asp不允许应用程序共享他们的application和session变量,换句话说,就是应用程序a不能访问应用程序b(包括web root,因为web root也是看作一个应用程序的根。)的application和session变量,他们是私有的。反之亦然。当你确信这个应用程序不需要与整个website、website上其他子目录上的asp脚本共享application和session变量,或者你想在同样的内存空间里隔离一个进程来运行应用程序时。你使用virtual applications是正确的。
要注意的一点是:在iis 4.0里面的“新虚拟目录向导” 所建立的virtual directory(虚拟目录)缺省就是一个virtual application(虚拟应用程序)。要把它变回virtual directory的话,你可以在目录的“属性”里,选择“目录”标签,单击“卸载”。
小心使用多个 global.asa
在一个website里面使用多个global.asa,我们必须要注意,因为那是很容易导致变量超出范围而丢失的。通常我们必须限制在整个website上的global.asa的树木,在每一个应用程序的的根目录里面放一个。这是保持session和application变量比较好的方法,不至于它们会丢失。通过在各个目录上放置global.asa文件,我测试的asp文件,可以帮助我们理解它们的关系。
例子,下面是一个website的设置。在这个website下面有两个目录。一个virtual application(虚拟应用程序)叫admin,一个virtual directory(虚拟目录)叫images。在每一个目录下有2个文件:global.asa和default.asp。每一个目录里的default.asp都是一样的,global.asa则根据不同的目录有所改变。
这个是default.asp的内容:
<%
response.write "session application_directory = <b>" &
session("application_directory") & "</b><br>"
response.write "session virtual_directory = <b>" &
session("virtual_directory") & "</b><br>"
response.write "session directory = <b>" & session("directory") & "</b><br>"
%>
website root上global.asa的内容:
sub session_onstart
session("virtual_directory") = "executed"
session("directory") = "executed"
end sub
当你用浏览器浏览default.asp时,得到的结果是:
session application_directory =
session virtual_directory = executed
session directory = executed
virtual directory(虚拟目录) images 上global.asa的内容是(把websiteroot上的global.asa稍微做修改):
sub session_onstart
session("virtual_directory") = "virtual directory"
session("directory") = "virtual directory"
end sub
用浏览器浏览default.asp(images上的default.asp)时,得到的结果是:
session application_directory =
session virtual_directory = executed
session directory = executed
虽然在这个目录上的global.asa文件里,我们为session变量赋了新的值。但是显示的仍然是website root上global.asa所设的值。
virtual application(虚拟应用程序) admin 上 global.asa的内容:
sub session_onstart
session("application_directory") = "executed"
end sub
用浏览器浏览default.asp(admin上的default.asp)时,得到的结果是:
session application_directory = executed
session virtual_directory =
session directory =
正如你所看到的,session("virtual_directory")和session("directory") 的值不能从root web 那里“带”过来。
global.asa 参考
global.asa 文件是一个可选文件,用户可以在该文件中指定事件脚本,并声明具有会话和应用程序作用域的对象。该文件的内容给用户显示的,而是用来存储事件信息和由应用程序全局使用的对象。该文件的名称必须是 global.asa 且必须存放在应用程序的根目录中。每个应用程序只能有一个 global.asa 文件。
global.asa 文件只能包含如下内容:
用程序事件(application_onstart、application_onend)
会话事件(session_onstart、session_onend)
<object> 声明
typelibrary 声明
如果包含的脚本没有用 <script> 标记封装,或定义的对象没有会话或应用程序作用域,则服务器将返回错误。服务器会忽略已标记的但未被应用程序或会话事件使用的脚本以及文件中的 html 语句。
可以用任何支持脚本的语言编写 global.asa 文件中包含的脚本。如果多个事件使用同一种脚本语言,就可以将它们组织在一组 <script> 标记中。
当用户保存对 global.asa 文件所做的更改时,在重新编译 global.asa 文件之前,服务器会结束处理当前应用程序的所有请求。在此期间,服务器拒绝其他请求并返回一个错误消息,说明正在重启动应用程序,不能处理请求。
当用户当前的所有请求处理完之后,服务器对每个会话调用session_onend 事件,删除所有活动会话,并调用 application_onend 事件关闭应用程序,然后编译 global.asa 文件。接下来,用户的请求将启动应用程序并创建新的会话,触发 application_onstart 和 session_onstart 事件。
但是,保存 global.asa 文件中所包含的文件的更改并不能使服务器重新编译 global.asa。为了让服务器识别包含文件的改动,必须再保存一下global.asa 文件。
在 global.asa 文件中声明的过程只能从一个或多个与application_onstart、application_onend、session_onstart 和session_onend 事件相关的脚本中调用。在基于 asp 的应用程序中的 asp 页中,它们是不可用的
