狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频

當前位置:系統之家 > 技術開發教程 > 詳細頁面

淺談asp編程中的測試打印、有效果性檢查及出錯處理

淺談asp編程中的測試打印、有效果性檢查及出錯處理

更新時間:2019-07-07 文章作者:未知 信息來源:網絡 閱讀次數:


經常看到一些初學asp的朋友為了測試一個值到處用response.write來打印,

而要看頁面效果時再刪除這些語句或加上注釋,在正式版本出來以前要如此反復

多次。而有些人為了減少麻煩,干脆全當它是正確的,不做測試輸出,像這樣極

易出現各種各樣的問題,最常見的是如果要生成一條sql語句,需要使用變量,如

果不做測試打印,很難做到一次正確,在chinaasp論壇里經常見到這種問題,老

是有人問這條語句為什么會出錯等問題,實際上他只要打印出這條語句看一下語

法是否正確就行了,而不必到處追著人問。事實上好的編程習慣應該是在自己沒

有很大把握的情況下把生成的語句或變量值打印出來,但這樣做又費時費力,有

沒有比較好的解決方法呢?
在C里可以使用 _DEBUG這樣的測試開關來控制debug版本和release版本,但

asp中并沒有類似#define這種語句,那么是不是我們就沒有辦法了呢?其實我們

可以仿照c的這種做法,那就是在global.asa文件里定義一個application變量來

控制,象下面這個例子:

在global.asp里加上:
application("DEBUG") = 1

然后做這么一個過程:
'--------------------------------------------------------
'Name: PRINT
'Argument: a_strPrint: 打印字符串
'Return:
'Description: 打。▋H在DEBUG狀態下運行)
'Hitory: Create by bigeagle
'--------------------------------------------------------
Sub PRINT(a_strPrint)
if Application("DEBUG") = 1 then
Response.Write("<P aling=center>"+a_strPrint+"</P>")
end if
End Sub

這個過程的功能就是當測試開關打開時(application("DEBUG") = 1)打印

,而當測試開關關閉(application("DEBUG") = 0)就不會有打印輸出了。這樣

在程序調試期間,你可以打開測試開關,以觀察變量的值,而當要看頁面效果或

發布release版本時就可以關閉測試開關,這樣所有的測試輸出就不會出現在頁面

上。

以上談到的是變量的測試輸出,下面要談談正確性檢測問題。經常見到很多

人把頁面提交過來或數據庫取出的值想都不想就用,根本不做正確性檢測,那你

怎么能保證這些值的正確性呢?比如有一個input,提交后它的值應該是一個值包

含數字的字符串,但如果用戶的輸入包含其他字符,若不做正確性檢測,那當你

用cint或clng轉換時就會發生錯誤,整個程序崩潰。另外一種情況是這樣,當你

從數據庫中取值或諸如此類的操作,應該是不會發生問題,但如果出現數據庫出

錯等問題,那么用戶也只能見到一個諸如'odbc錯誤'等等的提示信息,對于一個

成熟的商品程序來說,這點是很不好的,其實現在包括國內很多知名站點也出現

這種問題。所以應該養成這樣一個習慣,那就是任何可能出問題的變量、參數在

使用之前都應該做正確性檢測,并且對數據庫操作后應當判斷否成功。這是就又出現一個版本問題,如果是DEBUG版則應顯示出錯信息以備修改,而release版則應該引導到一個統一頁面,如“本站暫時出現未知故障,請稍候再來"等等,原則上永遠不要給用戶一個系統出錯信息頁面。要實現上述功能,請看以下幾個函數和過程。

'--------------------------------------------------------
'Name: ASSERT
'Argument: a_blnConditon: 斷言條件
' a_FunctionName: 調用函數
' a_ErrorString: 錯誤描敘
'Return:
'Description: 斷言
'Hitory: Create by Bigeagle
'--------------------------------------------------------
Sub ASSERT(a_blnConditon,a_FunctionName,a_ErrorString)
if Application("DEBUG") = 0 then
if a_blnConditon <> TRUE then
response.redirect("../include/bigerror.asp")
end if
else
if a_blnConditon <> TRUE then
call print("斷言錯誤:在<font color=red>" + a_FunctionName + "</font>出現:" + a_ErrorString)
response.end

end if

end if

End Sub

這個過程的作用是檢測變量或參數有效性,如果條件a_blnCondition<>true,那么如果測試開關打開,則顯示錯誤信息,如果測試開關關閉,則重定向到錯誤處理頁面bigerror.asp。


'--------------------------------------------------------
'Name: CheckError
'Argument:
'Return:
'Description: 檢查錯誤
'Hitory: Create by Yaozhigang
'--------------------------------------------------------
Function CheckError()
Dim intErrNumber
intErrNumber = Err.Number '保存錯誤代碼,因為在ERROR中將執行Err.Clear

if intErrNumber <> 0 then Call ERROR(-1, "") 'Err錯誤的錯誤碼為-1

CheckError = intErrNumber
End Function


'--------------------------------------------------------
'Name: ERROR
'Argument: a_intErrCode:錯誤碼(-1時表示是系統錯誤,即Err.Number<>0)
' a_strErrText:錯誤描述
'Return:
'Description: 錯誤處理
'Hitory: Create by Yaozhigang
'--------------------------------------------------------
Sub ERROR(a_intErrCode, a_strErrText)

Dim strMsg
Dim strLogMsg

'如果是Err錯誤,則一定執行錯誤頁
if a_intErrCode = -1 then

strMsg = strMsg + "*********************************************************************************************" + "<BR>"
strMsg = strMsg + "錯誤時間:" + CStr(Now()) + "<BR>"
strMsg = strMsg + "錯誤類型:Err錯誤" + "<BR>"
strMsg = strMsg + "錯誤號 :" + CStr(Err.Number) + "<BR>"
strMsg = strMsg + "錯誤源 :" + Err.Source + "<BR>"
strMsg = strMsg + "錯誤描述:" + Err.Description + "<BR>"
strMsg = strMsg + "*********************************************************************************************" + "<BR>"

strLogMsg = strLogMsg + "*********************************************************************************************" + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "錯誤時間:" + CStr(Now()) + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "錯誤類型:Err錯誤" + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "錯誤號 :" + CStr(Err.Number) + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "錯誤源 :" + Err.Source + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "錯誤描述:" + Err.Description + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "*********************************************************************************************" + Chr(13) + Chr(10)

'清空Err
Err.Clear

'在Redirect之前寫日志
WriteLog(strLogMsg)

strMsg = Server.UrlEncode(strMsg)
'如果是調試則顯示錯誤代碼
if Application("DEBUG") = 1 then
Response.Redirect("../include/error.asp?" + _
"ErrText="&strMsg&"")
else
Response.Redirect("../include/error.asp")
end if

'如果是程序錯誤,則寫日志
else

strMsg = strMsg + "*********************************************************************************************" + "<BR>"
strMsg = strMsg + "錯誤時間:" + CStr(Now()) + "<BR>"

strLogMsg = strLogMsg + "*********************************************************************************************" + Chr(13) + Chr(10)
strLogMsg = strLogMsg + "錯誤時間:" + CStr(Now()) + Chr(13) + Chr(10)

Dim strWhichErr
Select Case a_intErrCode

Case 99001 '程序錯誤從99001開始
strWhichErr = "斷言錯誤"
Case 99002
strWhichErr = "Case Else 錯誤"
Case else
strWhichErr = "未知的錯誤"
End Select

strMsg = strMsg + "錯誤類型:" + strWhichErr + "<BR>"
if a_strErrText <> "" then
strMsg = strMsg + "錯誤描述:" + a_strErrText + "<BR>"
end if
strMsg = strMsg + "*********************************************************************************************" + "<BR>"

strLogMsg = strLogMsg + "錯誤類型:" + strWhichErr + Chr(13) + Chr(10)
if a_strErrText <> "" then
strLogMsg = strLogMsg + "錯誤描述:" + a_strErrText + Chr(13) + Chr(10)
end if
strLogMsg = strLogMsg + "*********************************************************************************************" + Chr(13) + Chr(10)

'寫日志
WriteLog(strLogMsg)

'如果是調試狀態則指向錯誤頁
if Application("DEBUG") = 1 then
strMsg = Server.UrlEncode(strMsg)
Response.Redirect("http://server1/4biz/include/error.asp?" + _
"ErrText="&strMsg&"")
end if
end if
End Sub


'--------------------------------------------------------
'Name: WriteLog
'Argument: a_strMsg:日志內容
'Return:
'Description: 錯誤處理
'Hitory: Create by Yaozhigang
'--------------------------------------------------------
Function WriteLog(a_strMsg)
Dim strFileName

if Application("g_strLogFileName") = "" then
strFileName = "c:\AspLog.txt"
else
strFileName = Application("g_strLogFileName")
end if

Dim objFSO
Dim objFile
Set objFSO = CreateObject("Scripting.FileSystemObject")

'只有一個人寫日志
Application.Lock

Set objFile = objFSO.OpenTextFile(strFileName, 8, True, 0)
objFile.Write(a_strMsg)
objFile.Close

Application.UnLock

Set objFile = Nothing
Set objFSO = Nothing
End Function

以上幾個函數及過程的作用是處理數據庫錯誤,注意使用時在global.asp里加上on eroor resume,以使錯誤處理程序能夠運行。其中可以顯示錯誤代碼、寫日志文件,詳細內容我就不做解釋了,請自己研究一下源代碼。
(出處:熱點網絡)

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频
五月天中文字幕一区二区| 亚洲国产精品一区二区第四页av| 天堂成人免费av电影一区| 亚洲精品中文在线影院| 中文字幕一区av| 国产精品久久久久久亚洲毛片| 久久婷婷国产综合精品青草| 精品国产乱码久久久久久闺蜜| 日韩一区二区三区av| 欧美一区二区私人影院日本| 3d动漫精品啪啪| 精品国产人成亚洲区| 精品国产乱码久久久久久免费| 欧美va亚洲va香蕉在线| 欧美精品一区二区三区很污很色的| 日韩精品一区二区在线观看| 久久久777精品电影网影网 | 日韩精品一区二区三区中文精品| 欧美人狂配大交3d怪物一区| 欧美一二三区在线观看| 欧美精品一区二区三区四区| 国产蜜臀av在线一区二区三区| 成人欧美一区二区三区白人| 亚洲国产aⅴ成人精品无吗| 午夜视频一区二区三区| 久久99久久99| 成人app在线| 亚洲欧洲日夜超级视频| 亚洲一区bb| 7777女厕盗摄久久久| 久久久久久亚洲综合影院红桃| 国产精品久久久久久久久久免费看| 一区二区激情视频| 黄色精品一二区| 午夜精品一区二区三区四区 | 亚洲女性喷水在线观看一区| 日产精品久久久久久久性色| 福利视频网站一区二区三区| 好看的亚洲午夜视频在线| 蜜乳av另类精品一区二区| 日韩一区二区三区视频在线观看| 中文欧美字幕免费| 天天综合天天做天天综合| 国产精品77777| 影音先锋亚洲精品| 欧美亚洲一区二区在线观看| 26uuu国产电影一区二区| 亚洲一区二区三区四区在线免费观看| 免费观看在线综合色| 99视频在线精品| 久久国产精品一区二区三区| 精品国产乱码久久久久久老虎| 伊人色综合久久天天人手人婷| 精品精品欲导航| 欧美一级一区二区| 亚洲午夜久久久久久久久电影网| 国产在线不卡一卡二卡三卡四卡| 雨宫琴音一区二区在线| 7777精品伊人久久久大香线蕉超级流畅 | 日韩视频一区| 日韩美一区二区三区| 亚洲成人自拍偷拍| 99精品欧美一区二区蜜桃免费| 久久激情中文| 国产精品乱码久久久久久| 国产不卡视频在线播放| 羞羞答答国产精品www一本| 久久久久久免费| 激情图片小说一区| 亚洲欧美日韩国产一区| 日本一区二区三级电影在线观看| 激情综合色综合久久| 亚洲欧美99| 亚洲欧美日韩小说| 99国产精品久久久久久久久久| 欧美视频一区在线观看| 亚洲一区免费观看| 影音先锋久久精品| 欧美不卡一区二区三区| 麻豆久久一区二区| 麻豆av一区二区三区| 国产精品嫩草久久久久| 91在线看国产| 欧美电影免费提供在线观看| 国产成人啪午夜精品网站男同| 91国偷自产一区二区使用方法| 亚洲福利一二三区| 影音先锋久久| 国产精品麻豆视频| 欧美国产综合视频| 精品国产91洋老外米糕| 国产91精品精华液一区二区三区 | 亚洲免费婷婷| 亚洲精品视频一区| 亚洲电影专区| 国产精品久久久久久久久免费相片| 91亚洲午夜精品久久久久久| 欧美电影免费观看完整版| 国产999精品久久久久久绿帽| 欧美老肥妇做.爰bbww视频| 麻豆精品新av中文字幕| 欧洲精品中文字幕| 老司机免费视频一区二区三区| 色老汉av一区二区三区| 日本一区中文字幕| 欧美三级日韩三级国产三级| 蜜臀久久久久久久| 欧美亚洲图片小说| 国产精品亚洲人在线观看| 7777精品伊人久久久大香线蕉最新版| 韩国精品一区二区| 欧美丰满高潮xxxx喷水动漫| 成人国产免费视频| 久久日一线二线三线suv| 91美女福利视频| 国产精品免费丝袜| 99视频在线精品国自产拍免费观看| 一区二区三区久久| 美女精品国产| 久久91精品久久久久久秒播| 欧美一区二区精品在线| av在线不卡电影| 中文字幕亚洲不卡| 亚洲影视综合| 国模大尺度一区二区三区| 日韩欧美色综合| 午夜精品美女久久久久av福利| 亚洲欧洲成人av每日更新| 麻豆精品传媒视频| 国产麻豆视频一区二区| 久久久久久久久久久久电影 | 日韩码欧中文字| 久久精彩视频| 粉嫩aⅴ一区二区三区四区五区| 久久久久99精品一区| 一本久道久久综合婷婷鲸鱼| 免费av成人在线| 久久久久久麻豆| 国产嫩草一区二区三区在线观看| 午夜av一区二区三区| 欧美xxxxx牲另类人与| 亚洲国产高清一区| 久久99精品久久久| 国产精品免费网站在线观看| 久久亚洲欧洲| 99r国产精品| 一区二区三区四区在线免费观看| 7777精品伊人久久久大香线蕉| 午夜精品亚洲| 久久91精品国产91久久小草 | 欧美日本国产精品| 日韩经典一区二区| 国产日韩av一区| 色综合久久久久综合体桃花网| 成人av在线一区二区三区| 亚洲国产欧美在线| 精品国内二区三区| 久久午夜影视| 国产精品国产精品| 国产尤物一区二区在线| 亚洲精品日韩一| 精品国产免费视频| 一本到高清视频免费精品| 女人色偷偷aa久久天堂| 蜜臀精品一区二区三区在线观看| 国产精品色在线观看| 91精品久久久久久久91蜜桃| 一本色道88久久加勒比精品| 成人午夜在线播放| 日本欧洲一区二区| 一区二区三区高清| 国产人成亚洲第一网站在线播放| 久久综合亚州| 一本色道久久综合一区| 中文久久精品| 欧美黄色一区| 国产999精品久久久久久绿帽| 日本 国产 欧美色综合| 1024亚洲合集| 久久婷婷国产综合精品青草| 7777女厕盗摄久久久| 色婷婷久久一区二区三区麻豆| 欧美涩涩网站| 91丝袜呻吟高潮美腿白嫩在线观看| 久久精品国产亚洲a| 亚洲综合视频在线观看| 国产精品久久久久一区二区三区| 欧美夫妻性生活| 欧美天堂亚洲电影院在线播放| 亚洲一区视频| 国产欧美大片| 一二三区精品| 欧美在线视频二区| 欧美mv和日韩mv国产网站| 一区二区三区精品在线观看| 国产一区二区不卡| 国产精品亚洲综合久久| 国产日韩欧美精品电影三级在线| 黑人巨大精品欧美一区| 欧美一区激情|