ASP的错误处理集锦Word格式.docx
《ASP的错误处理集锦Word格式.docx》由会员分享,可在线阅读,更多相关《ASP的错误处理集锦Word格式.docx(14页珍藏版)》请在冰点文库上搜索。
![ASP的错误处理集锦Word格式.docx](https://file1.bingdoc.com/fileroot1/2023-5/8/ab1b871f-49f3-446e-be05-a12f309972a8/ab1b871f-49f3-446e-be05-a12f309972a81.gif)
3.逻辑错误:
逻辑错误是最难被发现的,这种错误经常是一种结构错误,电脑是发现不了的。
这就需要我们彻头彻尾地检查我们的代码。
因为编译错误一般是和逻辑错误一起发生的,一般都能显示出来,所以我们担心的就只是运行错误。
它都终止ASP的运行,而且给用户丢下一堆很不友好的文字。
则我们要怎样处理运行错误呢.
我们先来看看,ASP唯一提供给我们的错误命令---OnErrorResumeNe*t(这里提醒一下初学者,在ASP中只有OnErrorResumeNe*t语句,没有OnErrorResumeGoto语句)如果你不使用OnErrorResumeNe*t语句的话,一切运行错误都会发生,这个是致命的,则就会有一段错误代码“展现”给用户,而且ASP程序也会停止。
下面就是一个错误代码:
MicrosoftOLEDBProviderforODBCDriverserror80004005[Microsoft][ODBCDriverManager] Datasourcenamenotfoundandnodefaultdriverspecified/test.asp,line60
当我们在程序最上面使用OnErrorResumeNe*t语句时,所有的错误都会被忽略,程序会自动执行下一条语句。
这样程序就会完全执行,出错后用户也不会看到出错信息。
但是这样也有不好的地方,那就是如果程序没有按照你想像的执行的话,你就很难找到到底是哪里出了问题,所以你就得在必要的地方对错误进行处理。
处理错误
在ASP中,处理错误的最好的办法就是在程序最底端放上代码来处理错误。
我也推荐在每个ASP程序都使用缓冲区。
这样的话,如果错误发生,页面就会停止,页面内容也会被清除,这样用户就不会看到错误信息,对你们的抱怨也就少了!
下面是一个例子:
<
%LANGUAGE="
VBScript"
%>
%Response.Buffer=True
"
设置buffer为True
OnErrorResumeNe*t
开始错误处理
%>
%"
错误处理
IfErr.Number<
>
0Then
清除页面
Response.Clear
显示错误信息给用户
HTML>
HEAD>
TITLE>
/TITLE>
/HEAD>
BODYBGCOLOR="
*C0C0C0"
FONTFACE="
ARIAL"
Anerroroccurredinthee*ecutionofthisASPpage<
BR>
Pleasereportthefollowinginformationtothesupportdesk
P>
B>
PageErrorObject<
/B>
错误Number:
<
%=Err.Number%>
错误信息:
%=Err.Description%>
出错文件:
%=Err.Source%>
出错行:
%=Err.Line%>
/FONT>
/BODY>
/HTML>
%EndIf%>
你们上面看到了,我首先设置OnErrorResumeNe*t,这样出现错误就不会影响程序的执行。
错误处理和数据库
在错误处理中加入数据库的执行是很复杂的。
假若我们有一个程序,有很多的命令去向数据库中添加记录,如果insert/update在程序的最底部执行,如果我们前面又错误发生,那就完了!
我们就会向数据库中添加了一个错误的信息。
因为我们用了OnErrorResumeNe*t一切的错误都被忽略了!
即使前面出错,程序依旧会向数据库中添加数据的。
为避免这种情况,我们就先得做些手脚,正确处理的方法如下:
IfErr.Number=0AndobjConnection.Errors.Count=0Then
这里才能执行语句,因为没有错误
SetrstResults=dbData.E*ecute(t*tSql)
EndIf
更多高级的处理办法
当一个错误发生时,你们也可以显示更多的错误信息。
下面是同时处理数据库和页面错误的例子,有了它我们一下就能发现我们程序中的所有错误。
(由于有些地方我觉得英文更能说时问题,所以没有翻译)。
%IfErr.Number<
Response.Clear
SelectCaseErr.Number
Case8
"
指定错误的Number
在这里处理自定义错误
CaseElse
一般错误
IfIsObject(objConnection)Then
IfobjConnection.Errors.Count>
%>
<
DatabaseConnectionObject<
%
ForintLoop=0ToobjConnection.Errors.Count-1%>
ErrorNo:
%=objConnection.Errors(intLoop).Number%>
br>
Description:
%=objConnection.Errors(intLoop).Description%>
Source:
%=objConnection.Errors(intLoop).Source%>
SQLState:
%=objConnection.Errors(intLoop).SQLState%>
NativeError:
%=objConnection.Errors(intLoop).NativeError%>
%Ne*t
0Then%>
ErrorNumber<
ErrorDescription<
Source<
LineNumber<
%EndIf
EndSelect
EndIf%>
上面的例子让我们一下了处理了很多在数据库中出现的问题,这个在我们日常编程也是常用的!
我们也应该看到那个SelectCase语句,它能让我们来处理特定的错误。
Redirect和错误处理
有一点我们就当注意一下,就是我们常用到的redirect对象,如果一个页面中出现了redirect对象,则错误处理就失去了意义。
所以在转向之前我们还得处理一下,如下:
IfErr.Number=0AndobjConnection.Errors.Count=0Then
Response.Clear
Response.Redirectlt;
URLHere>
EndIf
把代码变得更整齐
为了让代码变得更整齐,首先把错误处理的文件放在一个包含文件中。
这样你就可以在任何文件中使用它。
这样修改也方便。
在你程序的最上方加入(当然在语言声明之后)OnErrorResumeNe*t语句。
在你执行SQL以前进行错误检查。
使用redirect以前也要进行错误处理。
让你处理错误的包含文件在代码的最上面
我希望这篇文章对你们有所用,因为我在我们的论坛中已经发现有人在问这个问题了!
也许我编译出这篇文章能对你们起些作用。
在这里