国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

response.end的優缺點介紹

2024-05-04 11:05:40
字體:
來源:轉載
供稿:網友

response.end在調試程序時占有很大的作用,當程序有重大問題的時候起到關鍵的作用,下面就讓我們一起來看看錯新技術頻道小編帶來的response.end的優缺點介紹吧!

首先講講它的好處。

調試程序的時候用處也很有用,類似設置斷點,特別是你的程序有重大問題,如有死循環的時候一般的response.write?? 查看中間結果是無法看到的,這時在response.write后加入response.end,這個查看中間結果很有用。

不過,如果使用 Response.End、Response.Redirect 或 Server.Transfer 方法,將出現 ThreadAbortException 異常。您可以使用 try-catch 語句捕獲此異常。
Response.End 方法終止頁的執行,并將此執行切換到應用程序的事件管線中的 Application_EndRequest 事件。不執行 Response.End 后面的代碼行。
此問題出現在 Response.Redirect 和 Server.Transfer 方法中,因為這兩種方法均在內部調用 Response.End。

解決方案 :

要解決此問題,請使用下列方法之一:
? 對于 Response.End,調用 HttpContext.Current.ApplicationInstance.CompleteRequest 方法而不是 Response.End 以跳過 Application_EndRequest 事件的代碼執行。
? 對于 Response.Redirect,請使用重載 Response.Redirect(String url, bool endResponse),該重載對 endResponse 參數傳遞 false 以取消對 Response.End 的內部調用。例如:
Response.Redirect ("Default.aspx", false);

Response.End()用法?

ASP開發中可能有時候會用大段的if... else 的判斷,不過如果是動態Response.write的內容,你想更方便閱讀代碼,可以用Response.End()來終端ASP的執行,也就類似于Break的用法,舉個例子:

if (userid="")or(password="") then Response.Write("<script lanuage=javascript>alert('UserName or Password is Empty!');location.href='../default.asp';</script>") Response.End() ‘這里進行了中斷 end if 下面是不為空進行讀取數據庫的操作,省略了n行代碼

這樣當傳入的用戶名或密碼為空時,自動write提示信息信息,然后Response.End()中斷程序,從而達到if 。。。else的作用。

另外使用Response.End的時候,就是我們日常調試程序的時候,比如

相輸出拼接的SQL語句,而不想執行下面的代碼,那么可以這么做

sql="select * from userinfo "response.Write(sql)response.End()rs.open sql ,conn,1,1 '這句是不會執行的

如果怕加入Response.End()的地方過多而正式發布時候不好注釋掉的化,可以用個函數將其封裝起來,如下面代碼:

sub debug() Response.End()end sub

上面的代碼修改如下:

sql="select * from userinfo "response.Write(sql)debug()rs.open sql ,conn,1,1 '這句是不會執行的

這樣當進行正式發布時,將函數debug中的語句注釋掉,就可以起到調試的作用,不過這個也有個問題就是,如果你使用太多的debug(),可能在調試的時候程序會不能按照需要進行中斷,可能有時候你不希望這些地方中斷執行,那么我們來進一步重構debug()函數,如下:

sub debug(isBreak) 'isBreak是boolean值的參數,如果設置為true的時候則進行中斷,否則,不進行中斷處理 if isBreak then Response.End() endend sub

使用時候代碼如下:

sql="select * from userinfo "response.Write(sql)debug(false)rs.open sql ,conn,1,1 '這句是會執行的rs.close()sql="select * from product "response.write(sql)debug(true)rs.open sql,conn,1,1 '這句不會執行

上文是錯新技術頻道小編帶來的response.end的優缺點介紹,上述的介紹基本上可以滿足我們控制中斷的需求,但這只是一個簡單的分析,可能還需要進行改善哦。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沧源| 乌兰浩特市| 黔东| 鄯善县| 清原| 绵竹市| 眉山市| 长海县| 重庆市| 鄢陵县| 沂水县| 清丰县| 广平县| 高青县| 弋阳县| 凉城县| 广灵县| 敦化市| 通榆县| 咸宁市| 宜章县| 土默特右旗| 神池县| 应城市| 道真| 夏津县| 西青区| 本溪市| 宣威市| 军事| 黄浦区| 汨罗市| 肥西县| 隆安县| 久治县| 饶阳县| 吉隆县| 锡林浩特市| 武汉市| 靖宇县| 乾安县|