ASP.NET MVC统一异常处理

前言:

今早看了篇文章:求知成瘾,却无作品 的思考;很有感触,发现原来自己也是这样,对每样东西都抱有很大的兴趣或者希望自己去学,一年后发现原来自己什么都是皮毛什么都不精!最终发现真正的大牛都是在某一个领域的大牛,不会是全能的。所以是时候精一下了。

本篇文章来源于今天的另外一篇阅读:《我的软件没bug》作者希望读者写的程序即使已经上线也能快速的发现自己bug而不是等着用户忍无可忍时的反馈,这样让用户产生错觉是其用的软件并没有bug,而能实现这些最关键的一点就是能不能发现bug。所以小猪今天写了其实已经关注非常久的一个主题:统一的异常处理

实现

ASP.NET MVC提供了很方便的实现处理异常的机制:在需要进行异常处理的Controller中重写OnException。如果整个程序都需要异常处理,可以先写一个BaseController,其他所有Controller都继承它,然后在BaseController中重写OnException。

protected override void OnException(ExceptionContext filterContext)
{
    Log(filterContext);
    base.OnException(filterContext);
}

private void Log(ExceptionContext filterContext)
{
    string fileName = System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, exceptionFileName);
    StreamWriter sw = System.IO.File.AppendText(fileName);

    System.DateTime dt = DateTime.Now;
    string ip = RY.Common.IPHelp.ClientIP;
    string url = Request.Url.ToString();
    sw.Write(string.Format("Time:{0:G}; ClientIp:{1}; URL:{2}; Message:{3}\n", dt, ip, url, filterContext.Exception.Message));
    sw.Close();
}

然后让自己的Controller继承自这个BaseController即可。

另外如果只是针对某一个Action的捕获异常则可以写一个Attribute继承自HandleErrorAttribute:

public class ExceptionLogAttribute:HandleErrorAttribute
{
       public override void OnException(ExceptionContext filterContext)
       {
            base.OnException(filterContext);
       }
}

存数据库还是文件

细心的读者可能发现上述的代码小猪是保存在网站跟文件夹下的一个文件里的。这里涉及到把异常数据保存在什么地方的问题。有两种选择数据库和文件。但是小猪考虑到存数据库时存在一个问题:当数据库无法链接时网站也是会报错,这个时候的错误如果是采用存在数据库的机制的话则无法记录,而存在文件里则不存在这个问题,除非是web服务器奔了。综上原因小猪采取了把日志文件存放在文件里的方法。

转载于:https://www.cnblogs.com/smallerpig/p/3646214.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值