前言:  

我们在实际项目开发中,经常会遇到一些不可预见的异常产生,有的异常在程序运行时就对其进行处理(try)
但是,有的程序不需要每一个地方都用try进行处理,那么针对这种情况,可以参照下面的方式,实现对异常的统一抓取处理,下面话不多说了,来一起看看详细的介绍吧。

方式一、Page_Error处理页面级未处理异常

作用域:当前的.aspx页面

描述:在需要处理的aspx页面的cs文件中,实现Page_Error方法,达到侦听当前页面未处理的异常

protected void Page_Error(object sender, EventArgs e)
  {
   string errorMsg = String.Empty;
   Exception currentError = Server.GetLastError();
   errorMsg += "来自页面的异常处理<br />";
   errorMsg += "系统发生错误:<br />";
   errorMsg += "错误地址:" + Request.Url + "<br />";
   errorMsg += "错误信息:" + currentError.Message + "<br />";
   Response.Write(errorMsg);
   Server.ClearError();//清除异常(否则将引发全局的Application_Error事件)
  }

方式二、通过HttpModule来捕获未处理的异常

作用域:全局的request请求

描述:通过一个类实现IHttpModule接口,并侦听未经处理的异常

实现步骤:

1、首先需要新建一个类(MyHttpModule),该类需实现IHttpModule接口,具体代码实例如下:

/// <summary>
 /// MyHttpModule
 /// </summary>
 public class MyHttpModules : IHttpModule
 {
     public void Init(HttpApplication context)
  {
   context.Error += new EventHandler(context_Error);
  }

  public void context_Error(object sender, EventArgs e)
  {
   //此处处理异常
   HttpContext ctx = HttpContext.Current;
   HttpResponse response = ctx.Response;
   HttpRequest request = ctx.Request;

   //获取到HttpUnhandledException异常,这个异常包含一个实际出现的异常
   Exception ex = ctx.Server.GetLastError();
   //实际发生的异常
   Exception iex = ex.InnerException;

   response.Write("来自ErrorModule的错误处理<br />");
   response.Write(iex.Message);

   ctx.Server.ClearError();
  }
}

2、配置文件配置相应的HttpModule节点

配置文件配置HttpModule节点时,有以下两种方式(根据IIS版本而异)

方法1、当IIS版本为7.0以下时,在<system.web>中新增如下配置节点

<httpModules>
  <add name="MyHttpModule" type="MyHttpModule.MyHttpModules,MyHttpModule" />
</httpModules>

方法2、当IIS版本为7.0及其以上版本时,在<system.webServer>中新增如下配置节点

<modules>
  <add name="MyHttpModule" type="MyHttpModule.MyHttpModules,MyHttpModule"/>
</modules>

方式三、通过Global中捕获未处理的异常

作用域:全局的request请求

描述:通过在Global中实现Application_Error方法,来达到侦听未经处理的异常

具体代码如下:

void Application_Error(object sender, EventArgs e)
  {
   //获取到HttpUnhandledException异常,这个异常包含一个实际出现的异常
   Exception ex = Server.GetLastError();
   //实际发生的异常
   Exception iex = ex.InnerException;

   string errorMsg = String.Empty;
   string particular = String.Empty;
   if (iex != null)
   {
    errorMsg = iex.Message;
    particular = iex.StackTrace;
   }
   else
   {
    errorMsg = ex.Message;
    particular = ex.StackTrace;
   }
   HttpContext.Current.Response.Write("来自Global的错误处理<br />");
   HttpContext.Current.Response.Write(errorMsg);

   Server.ClearError();//处理完及时清理异常
  }

有关三种异常抓取的总结分析:

以上三种方法根据IIS处理请求的顺序,可以知道,其三者触发的先后顺序是:

  方式一、Page_Error处理页面级未处理异常--抓取后未清理异常(ClearError)-->

  方式二、通过HttpModule来捕获未处理的异常--抓取后未清理异常(ClearError)-->

  方式三、通过Global中捕获未处理的异常

三种方式的作用范围是:方式一中作用于当前的aspx页面,方法二和方式三都作用于全局

通过上面的两点,所以在实际使用中,如果是抓取全局的未出来的异常建议采用方式二

如果是抓取某一页面的未处理的异常采用方式一

异常抓取后的处理逻辑总结:

按照上面的三种方式抓取到的程序中未处理的异常后,那么在实际的项目中,具体处理方式如何呢?根据自己实际的项目应用总结如下:

  {

    一般处理逻辑分三步:

    第一步:解析具体的异常信息

    第二步:解析后的异常信息落地入库(文本日志(方便后续查问题)

        、数据库日志(方便后续查问题,统计提醒))

    第三步:页面重定向(将错误重定向到定制的具体自定义错误页面)

        重定向时,不需要在异常抓取的时候处理,可通过配置文件实现灵活处理(具体实现方式,见下一篇)

        在异常抓取后,不要调用ClearError()来清除异常,否则配置文件设置的错误重定向将不起作用

  }

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

标签:
asp.net,全局异常处理,.net,全局异常处理,c,全局捕捉异常

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。