您现在的位置是:首页 >

不需要对异常信息进行处理 ASP.NET中处理异常的几种方式

火烧 2022-09-30 11:57:44 1070
ASP.NET中处理异常的几种方式    程序中使用try catch  对于预知会发生异常的代码段使用try catch主动捕获异常 适用于提示给用户或跳转到错误页面 或者通过其它方式处理异常(日志

ASP.NET中处理异常的几种方式  

   程序中使用try catch

  对于预知会发生异常的代码段使用try catch主动捕获异常 适用于提示给用户或跳转到错误页面 或者通过其它方式处理异常(日志 通知等)

  int i = ;

  int j = ;

  try

  {

  Label Text = (i / j) ToString()

  }

  catch (Exception ex)

  {

  // 这里处理异常 Redirect Transfer Log Notice等

  Console WriteLine( Page: + ex Message)

  }

   Global中使用Application_Error

  如果异常在程序中没有被处理(如没有try catch) 则异常的处理会流转到这个方法 这里边可以对异常进行处理 但是此方式不能捕捉子线程中的异常

  int i = ;

  int j = ;

  Label Text = (i / j) ToString()

  void Application_Error(object sender EventArgs e)

  {

  // 在出现未处理的错误时运行的代码

  Server Transfer( ErrorPage aspx )

  }

  string message = HttpContext Current Error != null ? (HttpContext Current Error InnerException != null ? HttpContext Current Error InnerException Message : string Empty) : string Empty;

  Label Text = message;

   在nfig中配置

不需要对异常信息进行处理 ASP.NET中处理异常的几种方式

  出现错误后跳转到ErrorPage aspx 和Application_Error类似 采用redirectMode模式可以传递异常到错误页面

   使用FirstChance异常通知

  关联到AppDomain 如果应用程序域内发生异常 则会首先触发这个事件 然后才查找catch块处理异常 不过在这个事件中不能处理异常 不能消灭异常 只是可以按照通知进行处理 因为如果这里处理了异常 catch块就不能进行处理了

  void Application_Start(object sender EventArgs e)

  {

  // 在应用程序启动时运行的代码

  AppDomain CurrentDomain FirstChanceException += new EventHandler<System Runtime ExceptionServices FirstChanceExceptionEventArgs>(CurrentDomain_FirstChanceException)

  }

  void CurrentDomain_FirstChanceException(object sender System Runtime ExceptionServices FirstChanceExceptionEventArgs e)

  {

  Console WriteLine(e Exception Message)

  // 错误 响应在上下文中不能使用

  // Response Redirect( ErrorPage aspx )

  // 错误 未将对象引用设置到对象的实例

  // Server Transfer( ErrorPage aspx )

  }

   绑定UnhandledException事件

  关联到AppDomain 关于这个事件并不是每次都能触发 和使用的方式有关 情况比较多 一般情况下我们只能获取这个异常 而不能阻止中断应用程序

  下边给出一个例子

  void Application_Start(object sender EventArgs e)

  {

  // 在应用程序启动时运行的代码

  AppDomain CurrentDomain UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException)

  }

  void CurrentDomain_UnhandledException(object sender UnhandledExceptionEventArgs e)

  {

  Console WriteLine(e Exception Message)

  }

  一般的未处理异常都会被Application_Error捕捉到 我们这里在线程中抛出一个异常

  另外StackOverflowException在 net 中不再能被UnhandledException捕捉到

  private void CutString()

  {

  //throw (new Exception( Test Unhandled exception ))

  //throw (new StackOverflowException( Test Unhandled exception ))

  }

  protected void Button _Click(object sender EventArgs e)

  {

  Thread th = new Thread(new ThreadStart(CutString))

  th Start()

  }

   延伸 子线程异常的处理 网上有介绍通过代理在主线程处理子线程的异常 但是在中是无状态的 主线程有可能很快消失 其中的某些处理可能执行失败

  这里使用Thread Sleep使主线程不会很快结束 这种异常处理起来很麻烦 不建议在中使用处理时间很长的线程

  protected void Button _Click(object sender EventArgs e)

  {

  Thread th = new Thread(new ThreadStart(() =>

  {

  try

  {

  throw (new Exception( Test Unhandled exception ))

  }

  catch (Exception ex)

  {

  //跳转到错误页面

  Response Redirect( ErrorPage aspx )

  }

  }))

  th Start()

  // 主线程会很快结束 这里让他等等页面跳转

  Thread Sleep( )

  }

lishixinzhi/Article/program/net/201311/12051  
永远跟党走
  • 如果你觉得本站很棒,可以通过扫码支付打赏哦!

    • 微信收款码
    • 支付宝收款码