使用log4net可以很方便地为应用添加日志功能。应用Log4net,开发者可以很精确地控制日志信息的输出,减少了多余信息,提高了日志记录性能。同时,通过外部配置文件,用户可以不用重新编译程序就能改变应用的日志行为,使得用户可以根据情况灵活地选择要记录的信息。

那么我们如何在Web项目中使用Log4Net呢?

配置方面请点击链接跳转上一笔记:

ASP.NET的错误处理机制之二(实例log4net)

这次主要针对上次的错误机制讲解如何进行Log4Net 在ASP.NET WebForm 和 MVC的全局配置

一、MVC中的全局配置

在项目中添加一个全局应用程序类Global.asax,如下图所示:

方法中添加如下代码:

    1. protected void Application_Start(object sender, EventArgs e)
    2. {
    3. #region 应用程序启动时,自动加载配置log4Net
    4.   XmlConfigurator.Configure();
    5. #endregion
    6. }
    7. protected void Application_Error(object sender, EventArgs e)
      {
      #region 捕获全局异常

      Exception error = Server.GetLastError().GetBaseException();
      Exception ex = Server.GetLastError().GetBaseException();
      string ip = Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR") == null ?
      Request.ServerVariables.Get("Remote_Addr").ToString().Trim() :
      Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR").ToString().Trim();
      string logpath = Server.MapPath("~/Log/" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
      StringBuilder builder = new StringBuilder();
      builder.AppendLine(string.Format("========== {0} Application_Error BEGIN ==========", DateTime.Now));
      builder.AppendLine("Ip:" + ip);
      builder.AppendLine("浏览器:" + Request.Browser.Browser.ToString());
      builder.AppendLine("浏览器版本:" + Request.Browser.MajorVersion.ToString());
      builder.AppendLine("操作系统:" + Request.Browser.Platform.ToString());
      builder.AppendLine("页面:" + Request.Url.ToString());
      builder.AppendLine("错误信息:" + ex.Message);
      builder.AppendLine("错误源:" + ex.Source);
      builder.AppendLine("异常方法:" + ex.TargetSite);
      builder.AppendLine("堆栈信息:" + ex.StackTrace);
      builder.AppendLine("========== Application_Error END ===================");

      lock (logpath)
      {
      try
      {
      using (var writer = new StreamWriter(logpath, true))
      {
      ZX.B2C.GoodBaby.Common.LogHelper.WriteLog(typeof(RequestNotification), builder.ToString());
      }
      }
      catch
      {
      // 防止写文件时,文件被人为打开无法写入等
      // 记录日志报错不做处理,不应影响用户继续使用
      }
      }

      Server.ClearError();
      Response.Redirect("/Error/ErrorPath404");//跳出至404页面

      #endregion
      }

二、WebForm中的全局配置

在项目中添加一个全局应用程序类Global.asax,如下图所示:

方法中添加如下代码:

  1. protected void Application_Start(object sender, EventArgs e)
    {
    #region 应用程序启动时,自动加载配置log4Net

    XmlConfigurator.Configure();

    #endregion
    }
    /// <summary>
    /// 捕获全局异常
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>

    protected void Application_Error(object sender, EventArgs e)
    {
    #region 捕获全局异常

    Exception error = Server.GetLastError().GetBaseException();
    Exception ex = Server.GetLastError().GetBaseException();
    string ip = Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR") == null ?
    Request.ServerVariables.Get("Remote_Addr").ToString().Trim() :
    Request.ServerVariables.Get("HTTP_X_FORWARDED_FOR").ToString().Trim();
    string logpath = Server.MapPath("~/Log/" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
    StringBuilder builder = new StringBuilder();
    builder.AppendLine(string.Format("========== {0} Application_Error BEGIN ==========", DateTime.Now));
    builder.AppendLine("Ip:" + ip);
    builder.AppendLine("浏览器:" + Request.Browser.Browser.ToString());
    builder.AppendLine("浏览器版本:" + Request.Browser.MajorVersion.ToString());
    builder.AppendLine("操作系统:" + Request.Browser.Platform.ToString());
    builder.AppendLine("页面:" + Request.Url.ToString());
    builder.AppendLine("错误信息:" + ex.Message);
    builder.AppendLine("错误源:" + ex.Source);
    builder.AppendLine("异常方法:" + ex.TargetSite);
    builder.AppendLine("堆栈信息:" + ex.StackTrace);
    builder.AppendLine("========== Application_Error END ===================");

    lock (logpath)
    {
    try
    {
    using (var writer = new StreamWriter(logpath, true))
    {
    ZX.B2C.GoodBaby.Common.LogHelper.WriteLog(typeof(RequestNotification), builder.ToString());
    }
    }
    catch
    {
    // 防止写文件时,文件被人为打开无法写入等
    // 记录日志报错不做处理,不应影响用户继续使用
    }
    }

    Server.ClearError();
    Response.Redirect("~/Error.htm");

    #endregion
    }

原文链接:

Log4Net 在ASP.NET WebForm 和 MVC的全局配置

Log4Net 在ASP.NET WebForm 和 MVC的全局配置的更多相关文章

  1. 解析ASP.NET WebForm和Mvc开发的区别

    因为以前主要是做WebFrom开发,对MVC开发并没有太深入的了解.自从来到创新工场的新团队后,用的技术都是自己以前没有接触过的,比如:MVC 和EF还有就是WCF,压力一直很大.在很多问题都是不清楚 ...

  2. 解析ASP.NET WebForm和Mvc开发的区别 分类: ASP.NET 2013-12-29 01:59 11738人阅读 评论(5) 收藏

    因为以前主要是做WebFrom开发,对MVC开发并没有太深入的了解.自从来到创新工场的新团队后,用的技术都是自己以前没有接触过的,比如:MVC 和EF还有就是WCF,压力一直很大.在很多问题都是不清楚 ...

  3. asp.net core 3.0 MVC JSON 全局配置

    asp.net core 3.0 MVC JSON 全局配置 System.Text.Json(default) startup配置代码如下: using System.Text.Encodings. ...

  4. ASP.NET中HttpApplication中ProcessRequest方法中运行的事件顺序;ASP.NET WebForm和MVC总体请求流程图

    ASP.NET中HttpApplication中ProcessRequest方法中运行的事件顺序 1.BeginRequest  開始处理请求 2.AuthenticateRequest 授权验证请求 ...

  5. [转]asp.net webform 与mvc 共享session

    公司内部系统最早是用.net webform模式开发的,现新项目用.net mvc 开发,现存在的问题就是如何保持原有.net webform的登录状态不变,而在mvc中能够验证用户的登录状态,也就是 ...

  6. asp.net webform 与mvc 共享session

    公司内部系统最早是用.net webform模式开发的,现新项目用.net mvc 开发,现存在的问题就是如何保持原有.net webform的登录状态不变,而在mvc中能够验证用户的登录状态,也就是 ...

  7. [转]解析ASP.NET WebForm和Mvc开发的区别

    因为以前主要是做WebFrom开发,对MVC开发并没有太深入的了解.自从来到创新工场的新团队后,用的技术都是自己以前没有接触过的,比如:MVC 和EF还有就是WCF,压力一直很大.在很多问题都是不清楚 ...

  8. Asp.Net WebForm和MVC同样优秀!

    不是说MVC不好,而是WebForm并没有那么不堪,和Mvc同样优秀.对说WebForm缺点多的,表示不服,求指教,虽然本人有些见解可能比较浅薄. 看过很多文章和书籍,都会拿MVC模式和WebForm ...

  9. ASP.NET WebForm与MVC优缺点

    发表于我的个人网站中,请点击阅读!

随机推荐

  1. As3 Practises : use TheMiner do as3 project swf performance profile , find memory leak!

    The second and most universal way is to launch it from the mm.cfg fileTheMiner.swf must be trusted1: ...

  2. 进程(并发,并行) join start 进程池 (同步异步)

    一.背景知识 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的一个抽象.进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所有 ...

  3. 转载:TCP连接的状态详解以及故障排查

    FROM:http://blog.csdn.net/hguisu/article/details/38700899 该博文的条理清晰,步骤明确,故复制到这个博文中收藏,若文章作者看到且觉得不能装载,麻 ...

  4. LUAROCKS 报错解决办法

    用luarocks 加载包时报错 Warning: falling back to curl - install luasec to get native HTTPS support 此时先安装 ./ ...

  5. Linux 下安装composer

    1.下载composer.phar文件. 2.将composer.phar文件上传linux. 3.执行 php composer.phar 4.全局安装:mv composer.phar /usr/ ...

  6. codechef Graph on a Table

    codechef Graph on a Table https://www.codechef.com/problems/TBGRAPH 题意 : 一个\(n\times m\)的网格图.\(q\) 个 ...

  7. 浅谈Sql各种join的用法

    1.left join.right join.inner join三者区别 left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右 ...

  8. java.lang.NoClassDefFoundError: org/apache/commons/io/output/DeferredFileOutputStream异常解决方法

    使用Tomcat部署Servlet程序时,单步调试跟踪到: List<FileItem> itemList = sfu.parseRequest(request); 总是会报错:Java. ...

  9. Ambari和YARN的Capacity调度器,安装过程

    用Spark测试YARN的资源池,测试过程中发现很多时候爆资源不够: 于是添加机器,专门用于跑spark:首先是ssh不通,原来错把71的id_psa.put文件拷贝到64上面:后来ssh通了,amb ...

  10. CentOS上面搭建SVN服务器

    1.安装svn sudo yum install subversion 查看安装位置 which svnserve 确认安装成功 svnserve --version 2.修改全局配置文件修改全局配置 ...