1.尽量用!--#INCLUDE FILE指令替代框架结构。
以前比较流行的一种设计模式就是使用一个框架(FRAME)放置网站的目录结构,在另外的框架中显示内容,这样的设计思路是必不可少的,但却会影响到网站性能。在具体实现方式上,完全可使用!--#INCLUDE FILE指令来设计一个导航条,至于INCLUDE的使用,早在讲座一中就已经举例说明。
2.尽量不要让来访者在毫无变化的等待中消磨时光。
不要使用这样的方式,先进行处理,然后再将处理结果输出到页面,造成在处理的这段时间内,客户端页面没有任何变化。一个再有耐心的人也会因此而感到无比懊恼,应该尽量采用边处理,边输出的方式。其实我们在讲座八中介绍的分页显示技术就是这个道理,下面再举一个例子。
代码一(先处理后显示):
<TABLE WIDTH=”100”>
<% WHILE NOT RS.EOF %>
<TR>
<TD><%=RS(“NAME”)%></TD>
<TD><%=RS(“EMAIL”)%></TD>
</TR>
<% RS.MOVENEXT
WEND %>
</TABLE>
代码二(边处理边显示,处理一条,显示一条):
<% WHILE NOT RS.EOF %>
<TABLE WIDTH=”100” BORDER=0>
<TR>
<TD><%=RS(“NAME”)%></TD>
<TD><%=RS(“NAME”)%></TD>
</TR>
</TABLE>
<% RS.MOVENEXT
WEND %>
3.避免使用SESSION变量,尤其是在页面之间使用SESSION变量。
4.不要盲目使用数据库。
初学者往往对数据库有所心得之后,动不动便使用数据库,一来可以温故,二来展示一下自己的数据库技术。我的建议是可以用别的方法时最好少使用数据库,访问数据库总要消耗服务器资源。例如你可以使用文本文件,此外,对一些不大改变而又经常使用的数据,可使用APPLICATION对象将数据存放在数组变量中,从内存中获取数据要比从数据库中快得多。
5.使用OPTION EXPLICIT强制声明变量。这可以提高ASP脚本执行效率,并且减少脚本出错的可能性,应该养成一个良好的习惯。
6.尽可能使用用DIM定义的局部变量。访问局部变量比访问全局变量或未声明的变量要快得多。
7.HTML代码和ASP代码最好不要频繁交叉,尽量使ASP代码或HTML代码连成片,以提升脚本运行效率(这跟打游戏的道理差不多)。
如果你是在代码中的好几个地方用<%=...%>格式书写输出结果,那么考虑一下把这些结果合到一块,用一个RESPONSE.WRITE语句写出来,如讲座二中的例WUF9.ASP。不要把HTML代码和VBSCRIPT脚本散布得太开,尽量写成成块的HTML和VBSCRIPT脚本。
8.适当使用绝对路径
如果可能的话尽量避免使用相对路径,而使用绝对路径。使用相对路径将需要IIS返回当前服务器路径,这就意味着对IIS的特殊请求造成执行速度低下。不过话说回来,慢是慢了点,然而使用相对路径可以大大增强程序的灵活性和可移植性,关键在于恰当的处理这对矛盾。
9.ASP脚本性能测试
你可以使用一些工具软件测试你的ASP脚本执行所花时间,尤其是觉得该脚本有问题时。这里提供几个,具体用法请看帮助。
(1) MICROSOFT的INETMONITOR工具:用来监控和测试整个网站的处理能力。下载地址:HTTP://WWW.MICROSOFT.COM/SITESERVER/SITE/DEPLOYADMIN/INETMONITOR.HTM。
(2) MICROSOFT的WEB CAPACITY ANALYSISTOOL(WCAT)。包含在MICROSOFT BACKOFFICE RESOURCE KIT光盘中,或者也可以去MICROSOFT网站下载。
(3) SOFTWING的ASP PROFILING COMPONENT,下载地址:HTTP://WWW.SOFTWING.COM/IISDEV/PROFILER/。
二、 有关数据库性能的优化
1.用直接将数据库绑定到OLE DB的驱动程序,而不通过ODBC。关于这一点,详见讲座六。
2.尽量使用系统默认的游标(CURSORTYPE)和上锁(LOCKTYPE)类型,尤其要避免使用动态游标。
3.适当使用存储过程。存储过程比查询字符串的效率高,使用起来要方便得多,好处多多。
4.及时释放资源,例如尽早的释放对象、关闭连接等。
5.数据库性能测试
(1) 测试SQL查询的速度,可以使用MICROSOFT ISQL/W(MICROSOFT SQL SERVER6.5)或MICROSOFT QUERY ANALYZER(MICROSOFT SQL SERVER7.0),它们可显示执行的每个步骤及所需时间。
(2) MICROSOFT SQL SERVER7.0的PROFILER,可以跟踪对数据库服务器上执行的查询的监控。例如,可以跟踪记录运行最慢的查询或是最经常导致数据库死锁的查询。
三、 另外几个问题
1.其他可选的ASP开发平台
此前我们所讲的ASP脚本均是在MICROSOFT系列平台上创建的,除此以外,你还可以选择CHILI!ASP来运行ASP,它的突出优点是在WINDOWS NT和UNIX平台上均可以使用。主页地址:HTTP://WWW.CHILISOFT.COM/。
2.关于<% @LANGUAGE=VBSCRIPT%>
此前我们所遇到的所有ASP脚本,开头第一行代码基本上都是<% @LANGUAGE = VBSCRIPT%>,这表明这一页的ASP脚本所使用的脚本语言为VBSCRIPT,实际上,在ASP中还可以使用JSCRIPT、PERLSCRIPT等其他脚本语言。
在ASP中,你可以设定整个WEB站点使用一种脚本语言(如VBSCRIPT,这也是IIS的缺省设置),而对某一个特定页面使用另一种脚本语言(如JSCRIPT),甚至于对某一个页面的某一个函数使用另一种脚本语言。下面我们举一个实例:
(1) 如何设定整个WEB站点所使用的脚本语言。
运行ISM(INTERNET SERVICE MANAGER)→右键击网站名,选择PROPERTIES→选择HOME DIRECTORY选项卡→单击CONFIGURATION按钮→选择APPLICATION CONFIGURATION对话框中的APP OPTIONS选项卡→在DEFAULT ASP LANGUAGE文本框中输入VBSCRIPT或JSCRIPT即可。
(2) 例程WUF99.ASP
<% @LANGUAGE = PERLSCRIPT %>
<HTML>
<HEAD><TITLE>BYE</TITLE></HEAD>
<BODY>
<%
%>
<SCRIPT LANGUAGE="JSCRIPT" RUNAT="SERVER">
FUNCTION SAYBYE()
{
RESPONSE.WRITE("再见!")
}
</SCRIPT>
<SCRIPT LANGUAGE="VBSCRIPT" RUNAT="SERVER">
FOR I=1 TO 3
SAYBYE()
NEXT
</SCRIPT>
</BODY>
</HTML>
注意:你可以在ASP中自由的使用VBSRIPT或JSCRIPT,因为MICROSOFT支持这两种(IE支持NETSCAPE的JAVASCRIPT,并将其发展为JSCRIPT,而NETSCAPE却不支持VBSCRIPT,这恐怕也是NETSCAPE先发后至,MICROSOFT官司缠身的原因之一),但是要使用PERLSCRIPT,必须另外安装PERL脚本语言环境。推荐使用ACTIVEPERL,在WINDOWS NT上安装非常方便,下载地址:HTTP://WWW.NEWHUA.COM.CN/ACTIVEPERL.HTM。
3.一个不错的ASP设计实例
网上有很多ASP的实例,主要集中在留言本、聊天室、新闻发布和BBS等,这里向大家推荐一个用ASP设计的BBS系统FREE BBS,下载地址为:HTTP://FREE_BBS.SOIM.NET/。