婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > asp.net開發中常見公共捕獲異常方式總結(附源碼)

asp.net開發中常見公共捕獲異常方式總結(附源碼)

熱門標簽:400電話辦理哪家性價比高 代理接電話機器人如何取消 天心智能電銷機器人 遂寧市地圖標注app 地圖標注的公司有哪些 地圖標注專業團隊 濮陽外呼電銷系統怎么樣 塔城代理外呼系統 地圖定位圖標標注

本文實例總結了asp.net開發中常見公共捕獲異常方式。分享給大家供大家參考,具體如下:

前言:在實際開發過程中,對于一個應用系統來說,應該有自己的一套成熟的異常處理框架,這樣當異常發生時,也能得到統一的處理風格,將異常信息優雅地反饋給開發人員和用戶。我們都知道,.net的異常處理是按照“異常鏈”的方式從底層向高層逐層拋出,如果不能盡可能地早判斷異常發生的邊界并捕獲異常,CLR會自動幫我們處理,但是這樣系統的開銷是非常大的,所以異常處理的一個重要原則是“早發現早拋出早處理”。但是本文總結的服務端公共捕獲異常處理可以寬泛地看做是在表現層的操作,要捕獲特定層的特定異常,不在討論范圍內。

1、BasePage類處理方式

在頁面的公共基類里重寫OnError事件。在前面這篇《asp.net實現非常實用的自定義頁面基類》里,樓豬已經貼了代碼,就不再費事了。根據經驗,很多人開發的時候幾乎都這么寫,而且對調試和維護還是很有幫助的。需要說明的是,每新添一個頁面,其對應類都必須繼承自BasePage類異常處理才起作用。

2、Global.asax處理方式

如1中所述,BasePage類的異常處理要求每一個aspx類文件都繼承它,適用性和性能顯然會打折扣。而Global.asax文件定義了asp.net應用程序中的所有應用程序對象共有的方法、屬性和事件,我們可以不采用BasePage的處理方式,在Global.asax里實現Application_Error事件并處理也可以。下面模仿BasePage類里的處理異常方法,實現如下:

/// summary>
/// 出錯處理:寫日志,導航到公共出錯頁面
/// /summary>
/// param name="sender">/param>
/// param name="e">/param>
protected void Application_Error(object sender, EventArgs e)
{
  if (Server.GetLastError() == null) return;
  Exception ex = Server.GetLastError().GetBaseException();
  string error = this.DealException(ex);
  DotNet.Common.Util.Logger.WriteFileLog(error, HttpContext.Current.Request.PhysicalApplicationPath + "LogFile");
  if (ex.InnerException != null)
  {
    error = this.DealException(ex);
    DotNet.Common.Util.Logger.WriteFileLog(error, HttpContext.Current.Request.PhysicalApplicationPath + "LogFile");
  }
  this.Server.ClearError();
  this.Response.Redirect("/Error.aspx");
}
/// summary>
/// 處理異常,用來將主要異常信息寫入文本日志
/// /summary>
/// param name="ex">/param>
/// returns>/returns>
private string DealException(Exception ex)
{
  this.Application["StackTrace"] = ex.StackTrace;
  this.Application["MessageError"] = ex.Message;
  this.Application["SourceError"] = ex.Source;
  this.Application["TargetSite"] = ex.TargetSite.ToString();
  string error = string.Format("URl:{0}\n引發異常的方法:{1}\n錯誤信息:{2}\n錯誤堆棧:{3}\n",
    this.Request.RawUrl, ex.TargetSite, ex.Message, ex.StackTrace);
  return error;
}

上面方式的好處是,寫一次代碼,應用程序發生的大部分異常它都給你捕捉處理了。樓豬要在這里由衷地發一番感慨,感謝ms為我們提供了這么優秀的框架,太省事了吧。

3、IHttpModule接口處理

1和2的處理方式大家都是非常熟悉的,樓豬在實際開發中基本上都是遵循上面兩種寫法,而且樓豬因為有了2中這種大小通吃的處理方式,甚至已經激動地感謝ms了。但是,在asp.net程序調用線程進行異步處理的時候,容易發生在后臺線程或線程池里拋出的異常并不能被1或(和)2完全捕捉到,這就涉及到asp.net下未捕獲異常的處理。也就是說樓豬以前做過的很多大小項目中對異常的處理是不完備的。這難道是nc樓豬沒有先謝國家種下的惡果嗎?感謝國家,感謝ms,感謝博客園,感謝無私的xdjm,感謝自己......

asp.net下未捕獲異常的處理步驟如下:

(1)、創建一個實現IHttpModule接口的類

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Text;
namespace DotNet.Common.WebForm
{
  using DotNet.Common.Util;
  /// summary>
  /// 通用未捕獲異常處理 
  /// /summary>
  public class AspNetUnhandledExceptionModule : IHttpModule
  {
    static object syncObj = new object();
    static bool isInit = false;
    public AspNetUnhandledExceptionModule()
    {
    }
    #region IHttpModule Methods
    public void Init(HttpApplication context)
    {
      lock (syncObj)
      {
        if (!isInit)
        {
          AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(OnUnhandledException);
          isInit = true;
        }
      }
    }
    public void Dispose()
    {
    }
    #endregion
    #region OnUnhandledException
    void OnUnhandledException(object o, UnhandledExceptionEventArgs e)
    {
      if (e.ExceptionObject == null) return;
      Exception ex = e.ExceptionObject as Exception;
      string error = string.Format("引發異常的方法:{0}\n錯誤信息:{1}\n錯誤堆棧:{2}\n",
              ex.TargetSite, ex.Message, ex.StackTrace);
      Logger.WriteFileLog(error, AppDomain.CurrentDomain.BaseDirectory + "LogFile");
    }
    #endregion
  }
}

(2)、web.config節點配置

httpModules>
   add name="AspNetUnhandledExceptionModule" type="DotNet.Common.WebForm.AspNetUnhandledExceptionModule, DotNet.Common.WebForm">/add>
/httpModules>

最后貼出測試代碼:

protected void Page_Load(object sender, EventArgs e)
{
  if (!IsPostBack)
  {
    System.Threading.ThreadPool.QueueUserWorkItem(new System.Threading.WaitCallback(Test), null);
  }
}
protected void Test(object state)
{
  int[] numArr = new int[100];
  numArr[100] = 100; //異常
}

需要說明的是,通過線程或者線程池處理的程序,在發生異常時,每個線程都會有它自己獨立的上下文,所以HttpContext對象應盡可能少地出現在異常處理階段。

小結:不知道還有多少童鞋認為異常處理就是在代碼里try...catch一下,拋出異常然后完事?如果有的話,呵呵,當年樓豬是拿“沒有人天生就是十全十美的”這句話來安慰自己的。當然了,try...catch也不是不可以,只能說明我們對待異常的態度太草率了。為了顯得我們的專業和全面,請參考其他異常處理專業性文章研讀一番,相比異常處理的核心思想(異常處理的“大智慧”),這篇文章總結的(異常處理的“小技巧”)對初學者而言可能也是誤導之作,請務必留意甄別。

完整實例代碼代碼點擊此處本站下載。

希望本文所述對大家asp.net程序設計有所幫助。

您可能感興趣的文章:
  • asp.net服務器上幾種常見異常的解決方案.
  • 在 .NET Framework 2.0 中未處理的異常導致基于 ASP.NET 的應用程序意外退出
  • ASP.NET生成eurl.axd Http異常錯誤的處理方法
  • asp.net Http異常eurl.axd出錯信息解決方法
  • Asp.net Mvc 身份驗證、異常處理、權限驗證(攔截器)實現代碼
  • ASP.NET mvc異常處理的方法示例介紹
  • asp.net 錯誤:0x8007000B 異常的解決方法
  • ASP.NET MVC異常處理模塊詳解
  • 在ASP.NET 2.0中操作數據之十八:在ASP.NET頁面中處理BLL/DAL層的異常
  • 在ASP.NET 2.0中操作數據之三十八:處理BLL和DAL的異常

標簽:河南 麗江 重慶 吉林 本溪 宜春 婁底 汕頭

巨人網絡通訊聲明:本文標題《asp.net開發中常見公共捕獲異常方式總結(附源碼)》,本文關鍵詞  asp.net,開發,中,常見,公共,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net開發中常見公共捕獲異常方式總結(附源碼)》相關的同類信息!
  • 本頁收集關于asp.net開發中常見公共捕獲異常方式總結(附源碼)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久久99久久| 欧美日韩国产免费| 一区二区三区不卡视频在线观看 | 日本成人在线一区| 国产.欧美.日韩| 欧美日韩久久久一区| 欧美激情综合五月色丁香| 日韩vs国产vs欧美| 91九色最新地址| 国产精品三级av在线播放| 午夜视频一区二区| 日本精品视频一区二区| 国产精品成人免费在线| 奇米精品一区二区三区在线观看 | 99久久99久久精品免费观看| 欧美中文字幕不卡| 亚洲乱码中文字幕| 日韩欧美综合在线| 91丝袜美腿高跟国产极品老师| 亚洲视频 欧洲视频| 91精品国产全国免费观看| 男女男精品网站| 日韩一区欧美一区| 日韩免费电影网站| 欧美在线短视频| 国产大片一区二区| 裸体健美xxxx欧美裸体表演| 国产精品久久久久7777按摩| 欧美日韩一二三区| 粉嫩久久99精品久久久久久夜| 免费国产亚洲视频| 亚洲大片免费看| 一区二区三区四区亚洲| 亚洲人成小说网站色在线| 国产调教视频一区| www国产亚洲精品久久麻豆| 欧美日韩国产精选| 欧美日韩综合色| 337p亚洲精品色噜噜狠狠| 欧美嫩在线观看| 日韩视频一区在线观看| 精品成人a区在线观看| 久久综合九色综合97婷婷| 欧美一区二区三区喷汁尤物| 欧美日韩国产bt| 久久亚洲一区二区三区四区| 久久综合九色综合97婷婷 | 一区二区三区在线免费播放| 最新日韩av在线| 蜜臀av性久久久久蜜臀av麻豆| 国内久久精品视频| 99精品热视频| 精品国产一区二区三区四区四| 日韩精品一区二区三区视频 | 国产偷v国产偷v亚洲高清| 亚洲人成网站色在线观看| 日本成人在线看| 在线观看一区二区视频| 久久久久高清精品| 蜜臀99久久精品久久久久久软件| 成人免费毛片嘿嘿连载视频| 欧美日韩精品一区二区在线播放| 久久九九久久九九| 久久成人18免费观看| 91看片淫黄大片一级在线观看| 日韩一级高清毛片| 性做久久久久久久免费看| 在线观看www91| 亚洲欧美激情一区二区| 91一区二区三区在线观看| 久久免费的精品国产v∧| 激情综合网av| 久久免费看少妇高潮| 国产精品伊人色| 久久综合九色综合久久久精品综合| 国产自产视频一区二区三区| 久久婷婷综合激情| 成人一级黄色片| 国产精品久久久久久久久免费樱桃 | 亚洲国产精品国自产拍av| 五月天一区二区三区| 6080午夜不卡| 国产精品69毛片高清亚洲| 久久综合99re88久久爱| 国产一区二区三区美女| 国产精品视频线看| 日韩三级免费观看| 成人禁用看黄a在线| 青草国产精品久久久久久| 久久先锋影音av鲁色资源网| 国产在线精品一区二区三区不卡| 国产精品欧美久久久久无广告 | 韩国一区二区三区| 亚洲高清一区二区三区| 亚洲一区电影777| 日本一区二区三区dvd视频在线| 欧美激情一区二区三区不卡| av电影在线观看完整版一区二区| 狠狠色狠狠色综合系列| 国产成人久久精品77777最新版本| 国产做a爰片久久毛片| 成人av电影免费在线播放| 成人黄色在线视频| 成人免费一区二区三区在线观看| 91精品视频网| 欧美日韩一级片网站| 99久久国产综合色|国产精品| 美国毛片一区二区| 亚洲伊人伊色伊影伊综合网| 国产精品久久久久影院老司| 日韩精品一区二区三区在线播放| 色八戒一区二区三区| 92国产精品观看| 91蝌蚪国产九色| 不卡一区二区在线| av中文字幕不卡| 99久久精品免费| av成人老司机| 欧美午夜精品久久久| 欧美日韩精品系列| 欧美成人a∨高清免费观看| 日韩精品一区二区三区在线| 国产丝袜美腿一区二区三区| 日韩精品一区二区三区视频在线观看 | 欧美男生操女生| 日韩免费福利电影在线观看| 国产欧美精品一区aⅴ影院| 国产精品久久久久四虎| 蜜桃久久精品一区二区| 91亚洲精华国产精华精华液| 精品视频免费在线| 国产精品网站在线观看| 一区二区三区波多野结衣在线观看| 婷婷开心激情综合| 日本乱人伦aⅴ精品| 国产亚洲欧美中文| 日本欧美肥老太交大片| 97成人超碰视| 夜夜亚洲天天久久| av一区二区三区四区| 国产无人区一区二区三区| 久久精品国产在热久久| 欧美三区在线视频| 水蜜桃久久夜色精品一区的特点| 在线视频综合导航| 亚洲成人精品在线观看| 在线中文字幕一区二区| 日韩av在线发布| 日本一区二区三区电影| 欧美最新大片在线看| 午夜婷婷国产麻豆精品| 欧美国产欧美综合| 2020国产成人综合网| 日本伊人精品一区二区三区观看方式 | 51精品国自产在线| 在线精品亚洲一区二区不卡| 成人性生交大合| 国产精品1区2区3区在线观看| 美女尤物国产一区| 一区二区在线观看免费视频播放| 日韩欧美国产一区二区三区| 91免费在线看| 国产剧情一区二区| 一区二区不卡在线视频 午夜欧美不卡在| 欧美精品1区2区3区| 大美女一区二区三区| 99久久久久久| 欧美日韩不卡视频| 六月丁香综合在线视频| 91麻豆精品久久久久蜜臀| 舔着乳尖日韩一区| 亚洲天堂免费看| 国产欧美日韩一区二区三区在线观看| 色激情天天射综合网| 91小视频免费观看| 国产91精品在线观看| 国产一区欧美日韩| 国产一区二区看久久| 美女视频一区在线观看| 亚洲成人免费看| 久久久久久久精| 国产精品久久二区二区| 国产亚洲精品福利| 久久久久久久av麻豆果冻| 亚洲国产高清aⅴ视频| 中文字幕国产精品一区二区| 久久久亚洲国产美女国产盗摄 | 日本一区二区电影| 精品亚洲免费视频| 日韩精品一级二级| 男女男精品视频| 国产91精品久久久久久久网曝门| 精品午夜久久福利影院| 国产精品亚洲综合一区在线观看| 蜜臀av一级做a爰片久久| 国产真实精品久久二三区| 国产精品自拍一区| 色哟哟欧美精品| 日韩三区在线观看| 亚洲美女淫视频|