狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

[點(diǎn)晴永久免費(fèi)OA]ASP和C#.net之response.end的優(yōu)缺點(diǎn)介紹

admin
2022年6月21日 16:25 本文熱度 1061

首先講講它的好處。

調(diào)試程序的時(shí)候用處也很有用,類似設(shè)置斷點(diǎn),特別是你的程序有重大問題,如有死循環(huán)的時(shí)候一般的response.write   查看中間結(jié)果是無(wú)法看到的,這時(shí)在response.write后加入response.end,這個(gè)查看中間結(jié)果很有用。

不過(guò),如果使用 Response.End、Response.Redirect 或 Server.Transfer 方法,將出現(xiàn) ThreadAbortException 異常。您可以使用 try-catch 語(yǔ)句捕獲此異常。
Response.End 方法終止頁(yè)的執(zhí)行,并將此執(zhí)行切換到應(yīng)用程序的事件管線中的 Application_EndRequest 事件。不執(zhí)行 Response.End 后面的代碼行。
此問題出現(xiàn)在 Response.Redirect 和 Server.Transfer 方法中,因?yàn)檫@兩種方法均在內(nèi)部調(diào)用 Response.End。

解決方案 :

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

Response.End()用法 

ASP開發(fā)中可能有時(shí)候會(huì)用大段的if... else 的判斷,不過(guò)如果是動(dòng)態(tài)Response.write的內(nèi)容,你想更方便閱讀代碼,可以用Response.End()來(lái)終端ASP的執(zhí)行,也就類似于Break的用法,舉個(gè)例子:

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

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

另外使用Response.End的時(shí)候,就是我們?nèi)粘U{(diào)試程序的時(shí)候,比如

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

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

如果怕加入Response.End()的地方過(guò)多而正式發(fā)布時(shí)候不好注釋掉的化,可以用個(gè)函數(shù)將其封裝起來(lái),如下面代碼:

sub debug() Response.End()end sub

上面的代碼修改如下:

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

這樣當(dāng)進(jìn)行正式發(fā)布時(shí),將函數(shù)debug中的語(yǔ)句注釋掉,就可以起到調(diào)試的作用,不過(guò)這個(gè)也有個(gè)問題就是,如果你使用太多的debug(),可能在調(diào)試的時(shí)候程序會(huì)不能按照需要進(jìn)行中斷,可能有時(shí)候你不希望這些地方中斷執(zhí)行,那么我們來(lái)進(jìn)一步重構(gòu)debug()函數(shù),如下:

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

使用時(shí)候代碼如下:

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

好了,這樣基本上可以滿足我們控制中斷的需求了,不過(guò)只是簡(jiǎn)單的進(jìn)行了分析,其實(shí)還很不完善,調(diào)試需求可能還有很多,需要滿足,還需要進(jìn)一步重構(gòu)。其實(shí)程序開發(fā)就是一個(gè)重構(gòu)重構(gòu)再重構(gòu)的過(guò)程,要不怎么會(huì)出來(lái)那么多的設(shè)計(jì)模式,都是前人從實(shí)際開發(fā)重構(gòu)過(guò)程總結(jié)出來(lái)的經(jīng)驗(yàn),值得大家借鑒。


該文章在 2022/6/21 16:26:28 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved