”); //Result is ‘24
’ Response.Write(“
” + intInteger + intInteger + “
”); ; &nbs p; //Result is ‘1212
’ 在第一种情况下,两个数相加,结果被转换为一个字符串并与“”字符串进行级联。在第二种情况下,第一个运算符是一个字符串和一个数的级联,所以数被转换为一个字符串。而后,所有的运算符都是级联运算符。为了避免这个问题,可以使用括号强制第一个运算符是两个数值的加法: Response.Write(“
” + (intInteger + intInteger) + “
”); ; &nbs p; //Result is ‘24
’ 1. Web应用程序中的组件管理 在ASP中使用虚拟应用程序的第二个主要方面是:具有较好的对在脚本代码内实例化和执行的组件进行管理的能力。先不讨论有关它怎样进行工作以及为什么会如此有用的详细情况,在学习ASP组件的部分时再讨论相关内容。 这里非常简要地介绍在ASP网页(此ASP网页在该应用程序中)中使用组件时,如何对一个虚拟应用程序在Properties对话框(在Internet Services Manager中)进行设置。 在一个虚拟应用程序的Properties对话框的Home Directory页的底部,有两个组合框,为Execute Permissions和 Application Protection,如图3-9所示: 图3-9 Execute Permissions和Application Protection组合框 应用的保护和执行设置 因为在本章中,不讨论在一个Web网页内如何创建组件的实例,因此这里先列出这些选项,在创建应用程序时可能要对此进行设置。Execute Permissions 选项如表3-1所示: 表3-1 Execute Permissions的选项及说明 选 项 说 明 None 在这个虚拟应用程序中不能运行脚本或可执行文件。实际上,提供了禁止一个应用程序的快速和简单的方法 ScriptsOnly 只允许脚本文件(例如ASP、IDC或其他的)在这个虚拟应用程序中运行,不能运行可执行文件 Scriptsand Executables 允许任何的脚本和可执行文件在这个虚拟应用程序内运行 Execute Permissions选项控制可在该虚拟应用程序中执行的类型,而Application Protection选项影响可执行文件和组件运行的方式。在第1章中已经讨论过可用的选项,但是在这里再重复一次,Application Protection选项如表3-2所示: 表3-2 Application Protection的选项及说明 选 项 说 明 Low(IIS Process) 带有这种设置的ASP虚拟应用程序的所有可执行文件和组件运行在Web服务器的可执行文件(Inetinfo.exe)的进程(即内存空间)中。因此,如果可执行文件或组件之一失败的话,Web服务器处于危险状态。这提供了最快和以最少的资源执行的选项 Medium(Pooled) (缺省)带有这种设置的ASP虚拟应用程序的所有应用程序的可执行文件和组件是运行在DLLHost.exe的单个共享实例的进程(即内存空间)中。这就防止了Web服务器可执行文件(Inetinfo.exe)受可执行文件或组件失败的影响。然而,一个失败的可执行文件或组件可能引起DLLHost.exe进程失败,以及所有其他驻留其中的可执行文件和组件失败 High(Isolated) 带有这种设置的ASP虚拟应用程序的所有应用程序的可执行部分和组件是运行在DLLHost.exe的单个共享实例的进程(即内存空间)中,但是每个ASP应用程序都有自己的DLLHost.exe实例,该实例对该应用程序是独占的。这就防止了Web服务器可执行文件(Inetinfo.exe)受可执行文件或组件失败的影响,并防止虚拟应用的单个共享实例受另一个虚拟应用程序的一个可执行文件或组件失败的影响。Microsoft建议最多有十个这样的虚拟应用程序驻留在一个Web服务器上 3.2.2 ASP会话的定义 ASP会话引入了一个Web应用程序中粒度的下一层。ASP的Application对象可用来存储对于“正在运行此应用程序”的所有用户都是全局的和可访问的状态(即简单变量、对象、数组等)。换句话说,用于响应这个应用程序内所有访问者的请求的全部ASP代码能够对这些值进行访问(假设已经建立了一个有效的会话,稍后将看到)。 但是在多数情况下这还不够。需要具备存储指定给每个用户的值的能力,而不必通过给这些值分配名字指明其隶属于哪个用户。例如,下列值很可能弄乱应用程序的全局存储空间: MikeJones003PrefFGColor = “darkblue” MikeJones003PrefBGColor = “white” MikeJones003PrefLinkClolr = “green” PriscillaDelores001PrefFGColor = “red” PriscillaDelores001PrefBGColor = “darkgrey” ... etc. 从载入系统资源和要求一些代码访问每个用户的相应会话的角度来看,还有另外的不足之处。只要有访问者,该应用程序就一直存在,这意味着应用程序的全局存储空间需要不断增大,除非在用户离开该网站时采取步骤删除这些值。 在Web应用程序中提供用户层作用域 除了使用全局变量的存储以外,应该为每个访问者分配他们自己的私有变量存储空间,使其对指定访问者载入的所有页面都可用的。这种情况下,可以对每个变量使用相同的名字,使ASP代码非常简单地得以实现。这些相同的代码对每个用户将透明地进行工作,因为访问的只是访问者拥有的私有存储区域: PrefFGColor = “darkblue” PrefBGColor = “white” PrefLinkColor = “green” 这就是Session对象产生的地方。 (1) 会话存储的内容 会话存储的内容对指定的访问者是全局的,而对其他访问者来讲是私有的,这使得ASP的会话非常有用。可以用来存储在 ASP Application对象中存储的相同类型的数据,即: · 简单变量,例如字符串和数值(像所有的ASP脚本变量一样存储为Variant)。 · Variant数组,一维或多维。 · 对一个COM对象的实例的变量引用(如同Variant)。 (2) 会话带来的问题 会话提供了一个存储每个用户特定的值的方法。然而有几个意想不到的问题要注意: · 记住一些浏览器和Web服务器对URL、路径和文件名的大小写形式是敏感的(例如Navigator和基于UNIX/Linux的服务器)。如果把一个超级链接放置在网页的一个URL上,并且它们不是同样的书写形式,则在浏览器中被认为是不相同的。同样,如果路径和文件名的书写形式不是相同的,则浏览器认为是不同的路径或文件。对于在服务器上的定位资源来讲,这并不重要,因为IIS对书写形式不敏感,可以接受大写形式和小写形式的任何组合,并返回书写形式不同的具有相同字符的文件。然而,如果一个cookie已经指定了一个路径,而且与在超级链接中所指定的路径在书写形式上不同,浏览器可能不会把它以及相应目录的页面一起返回给服务器。这有可能找不到依赖于这个cookie的一个用户会话,并且Session对象将不会在作用域中(即其中的任何变量都是不可用的)。因此,在所有的目录和网页名字中,坚持都采用小写形式或者是比较明显的混合字母形式,是一个好办法。 · 在IIS和ASP的早期版本中,对于嵌套的应用程序还有一些小的“Bug”,有时,当用户离开嵌套的ASP虚拟应用程序并返回到缺省的ASP应用程序层时,与嵌套应用程序内部已经定义的局部变量相同的名字的任何全局变量不能重新显现。还有,当会话使用Session.Abandon方法(稍后将会看到)终止时,global.asp文件中的代码将执行失败。在ASP 3.0中已经解决了这些问题。 · 记住会话依赖于cookie。如果访问者已经禁止使用cookie或者浏览器不支持cookie,将不能启动一个会话,并且不能访问Session对象。 (3) 禁止会话 虽然状态提供了有益环境,但让用户门户大开。如果不需要保留状态,可以禁止会话以节约计算机的处理时间。例如,在一个不需要跟踪访问者或不需要为访问者保留全局值的Web网站上,可以防止会话启动,通过在Internet Services Manager中设置属性,或为不需要状态的独立网页增加代码(稍后将看到)。 为了禁止整个Web网站的所有会话,可编辑缺省Web网站应用程序的属性。为了禁止一个指定应用程序的会话,可编辑相应虚拟应用程序的属性。打开相应的应用程序的Properties对话框,在Home Directory页上单击Configuration按钮,如图3- 10所示: 图3-10 Home Directory页 在出现的Configuration对话框中,打开App Option。这里可以允许或禁止整个应用程序的会话(在本例中是整个缺省Web 站点),也可以修改缺省的会话Timeout值。在图3-11中可以看到Timeout设置为20min。在ASP的早期的版本中这是缺省值,可根据要求设置相应的值(在ASP 3.0中,缺省值是10min)。 图3-11 App Options页 如果要禁止一个指定网页的会话,同时允许它们在同一个应用程序的其他网页中创建和使用,可为该页面增加一条ASP处理指令。它跟在指定缺省语言的语句后(如果没指定一个缺省语言,可单独使用该指令): 到此为止,大致介绍了ASP应用程序和Session对象的一些情况,下面详细地进行讨论。