浅谈ASP程序的编写和调试:给初学者

发表于:2007-06-30来源:作者:点击数: 标签:
很多朋友觉得ASP不是很好学,我觉得其实有了一定的编程基础,再加上那么一点点技巧,入门是不难的(不过要做好也不是很容易,要很多的相关知识——什么Sql Server 数据库 语言啦,数据结构啦(这些都是在优化Asp的算法时候要熟悉的)。 在这只和大家谈谈我个人

  很多朋友觉得ASP不是很好学,我觉得其实有了一定的编程基础,再加上那么一点点技巧,入门是不难的(不过要做好也不是很容易,要很多的相关知识——什么Sql Server数据库语言啦,数据结构啦(这些都是在优化Asp的算法时候要熟悉的)。

  在这只和大家谈谈我个人是怎书写和调试ASP的,希望能给大有一点帮助……

  ASP脚本的书写:

  一、注意区分清楚html语法和VBScript语法。因为ASP是混合使用Html语法和VBScript语法的(当然,我全部写成VBScript语法也可以,不过那样的程序那难阅读)。最好使用一些能标示html标记和VBScript标记的编辑工具,比如Ultra Edit什么的。

    我学得编辑器的工具栏菜单不用太多,有一般的功能就行了,因为工具菜单一多,编辑区域肯定会变得较小,这是我们不希望看到的(你总不希望为了找出一个If的结束语句End if而翻来翻去吧。这也许是我以前使用记事业来编写Asp脚本的原因吧——呵呵,记事本的编辑区域较大嘛……

  二、书写程序时使用缩进

    书写程序时使用缩进可以减少很多不必要的语法错误。以免执行你的asp程序的时候提示“缺少end”什么什么的……

    通常指使用缩进书写指的是对流控制语句使用缩进,如果我不说,你也应该知道有哪些流控制语句吧:

    If……Else……End if
    For……Next
    Do While……Loop
    Select case ……Case……Case Else……End Select
    For each element In group……Next

    等等……

    比如写成下面这样查错就方便多了:

    If 条件 then
      语句
      do while 条件
        语句
      loop
    else
      语句
    end if

  三、熟悉一些省略的写法,比如:

    If 条件 then
      语句
    End if
    可简写成If 条件 then 语句
    注意:后面不能再写else和end if。
    等等……

  四、尽量熟悉你要使用的脚本语言

  五、备用一些常用的教程(比如VBScript语言参考什么的),以备查用。

  六、拼写要十分小心


  Asp脚本的调试:

  一、在你编辑实现一定功能的Asp脚本时,首先得有一个清晰的思路,只要是:要实现什么功能,实现的关键是什么、语句流怎样控制等……虽然小的项目(比如一个简单的留言本系统)不一定要写出来,但起码要心中有数。

  二、如果要使用数据库的话,得先根据你的项目功能设计数据库结构

  三、不要等到整个Asp脚本全部编写完毕时才开始调试。一般都是一边编写一边调试(如果你看我做的话就是开两个窗口:一个编辑器,一个IE,在编辑中改一下脚本,再到IE窗口刷新一下)。

    如果你的脚本有几百行那么多,即使你只是将一段正确的脚本输入到文件里面,也难保不会出错。而这么长的脚本文件是很难调试的,一旦出现错误,你很难找出到底哪里出了问题——即使是语法错误。

  四、调试语法错误的时候,经常采用“截短法”来做。

    比如出错提示为“第236行错误,缺少end”,这样长的代码,你很难知道到底缺少的是那个If的end或者是select的end……

    比如下面一段程序:

一大堆语句
if

else
  (这里有一大堆语句)
end if

    我通常的做法是截去括号中的部分,然后再试运行,再逐步将截去的部分放回去(这特别适用于调试别人编辑的脚本)。

  五、标记调试方法

    有时为了知道程序执行到了哪个地方,通常在程序里加进一些标记,比如response.write "abc",然后将这句移动位置,这样就能确定程序到底有没有执行到我希望到的地方。

    在调试循环的时候,常常需要输出循环控制变量的值到浏览器以帮助调试。

    一些由于是变量值引起的错误,比如数据库连接或记录集打开错误,通常在出错语句的前面输出sql语句以确认sql语句没有错误。出于这个考虑,我通常使用sql="语句"/set  rs=execute(sql)来代替直接运行set rs=execute("语句"),因为当我的语句出错时,我可以很方便地在前面来个response.write sql来查看sql语句到底有没有问题。

  六、在调试表单时,对于password表单项,通常先将它变成text,等调试好了后才改为password。

  七、监视变量法

    在调试一些变量比较多的脚本时,比如聊天室调试时,由于大量使用到application和session变量,通常要做些辅助的脚本来查看application和session变量,这样就方便多了。

  八、以少代多法

    调试global.asa文件的逻辑错误是比较麻烦的,特别是session.onend和application.onend事件。

    applicatoin.onstart事件调试不难——因为当你第一次打开浏览器的时候,如果global.asa文件有语法错误的时候,浏览器会提示你什么地方出错了。但很不幸地,session.onend就看不到提示了。为了确认你的session.onend到底有没有执行,通常在application.onstart设置一个标记变量,然后在session.ond事件中将这个变量改成变一个值,这样就可以等session超时后查看该标记变量有没有被改变,如果没有改变就证明你的session.onend没有执行。

    对于application.onend的调试,你可以把那部分代码拿到一个asp文件中,给它一定的条件(比如它使用了什么变量,然后满足它的条件看看有没有达到预的效果。不过通常application.onend都不会太复杂(复杂了调试通不过呗)。

  九、尽量给一些数据库连接串全部的参数,以免引起不必要的麻烦。

    虽然一些参数不是必须的,但还是全部给它较好。我曾经试过由于没有给一个Aclearcase/" target="_blank" >ccess的数据库连接字符串足够的参数而引起离奇古怪的问题:修改了连接文件后,刷新一次可得到正确的结果,再来刷新一次就不行了,甚至出现了“无法指出的错误”。

  十、不要急于进行错误处理On_orror。因为错误本身可以帮我们调试脚本,你一旦屏蔽了错误,很容易不知道到底哪里出错了。

  十一、减少逻辑错误的一个最好的方法是有一个清晰的思路,别人是很难帮上你的。

    因此如果你在BBS上问一个逻辑错误,回答者首先的回答就是:“你的源代码呢?”,因此除非你是为了灌水,否则在BBS上问一个象这样“为什么我的记录集是空的”的问题是没有意义的。

原文转自:http://www.ltesting.net