`

.net mvc 如何使用 log4net 日志

阅读更多

         对与开发者来说,异常日记是比较重要的。他能精确定位,帮助我们准确攻破bugLog4net是一个著名的开源日志组件。利用log4net可以方便的将日志信息记录到文件中,并且我们还可以记载控制要记载的日志级别,可以记载的日志类别包括:FATAL(致命错误)、ERROR(一般错误)、WARN(警告)、INFO(一般信息)、DEBUG(调试信息)。要想获取最新版本的log4net组件库,可以到官方网站http://logging.apache.org/log4net/下载,或者用 NuGet extension manager 来添加log4net 到站点中:

PM> install-package Log4Net

1.在Web.config配置相关的配置文件

   

<configSections>     
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4Net"/>
  </configSections>
<!--日志的配置开始-->
    <log4net>
      <appender name="RollingFile" type="log4net.Appender.RollingFileAppender">
        <file value="D:\Temp\log4net.log" />
        <appendToFile value="true" />
        <maximumFileSize value="500KB" />
        <maxSizeRollBackups value="2" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date %level %logger - %message%newline" />
        </layout>
      </appender>
      <root>
        <level value="All" />
        <appender-ref ref="RollingFile" />
      </root>
    </log4net>
  <!--日志的配置结束-->

 2.在程序一开始的时候,我们需要在Global.asax.cs文件中的Application_Start事件中进行一下初始化配置。

   

protected void Application_Start()
        {

            AreaRegistration.RegisterAllAreas();
            WebApiConfig.Register(GlobalConfiguration.Configuration);
            FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
            RouteConfig.RegisterRoutes(RouteTable.Routes);
            BundleConfig.RegisterBundles(BundleTable.Bundles);
            //读取日志  如果使用log4net,应用程序一开始的时候,都要进行初始化配置
            log4net.Config.XmlConfigurator.Configure();
        }

 3我们可以写一个类,定义一个静态方法,这个方法将可以将我们的错误消息进行输出。因为不仅仅一个地方需要,所以我们把它定义为了静态方法。

class LogHelper
    {       
        public static void WriteLog(string txt)
        {
            ILog log = LogManager.GetLogger("log4netlogger");
            log.Error(txt);
        }
    }

 4.自定义一个类,使这个类继承自HandleErrorAttribute这个类,并重写其内部方法。这个方法内部代码的作用就是处理异常,将异常信息记录日志。

public class MyExceptionFileAttribute:HandleErrorAttribute
    {       
        public override void OnException(ExceptionContext filterContext)
        {
            base.OnException(filterContext);
            Common.LogHelper.WriteLog(filterContext.Exception.ToString());           
        }
}

 5.由于全局都需要进行异常的处理,我们需要在FilterConfig.cs RegisterGlobalFilters方法中注册我们自己的异常处理过滤器。

public static void RegisterGlobalFilters(GlobalFilterCollection filters)
        {
            filters.Add(new HandleErrorAttribute());
            filters.Add(new JsonExceptionFilterAttribute());
            //filters.Add(new HttpResponseExceptionAttribute());
            //注册异常处理过滤器。
            filters.Add(new MyExceptionFileAttribute());
        }

 例图:



 

 

 

 

 

  • 大小: 50 KB
分享到:
评论

相关推荐

    log4net Asp.net mvc 配置

    ### log4net在ASP.NET MVC中的配置与使用详解 #### 一、log4net简介 log4net是一款基于.NET平台的日志记录工具,它能够帮助开发者轻松地将日志信息写入磁盘文件以及发送电子邮件等。log4net是Apache Logging ...

    log4net_写日志_ASP.NET_MVC_WINFORM三合一DEMO

    `log4net`是一款广泛应用于.NET平台的日志框架,由Apache软件基金会开发,提供了强大的日志记录功能,适用于ASP.NET、MVC以及WinForms等多种应用程序。 **log4net简介** `log4net`的核心理念是提供一个可配置、可...

    .NET_Core2.0_使用swagger调试API接口_log4记录日志_外加上传图片

    通过学习和理解这个项目,你可以更好地掌握.NET Core 2.0中API开发的关键技术,包括Swagger的使用、log4net的日志管理以及文件上传的实现。如果你在实践中遇到问题,可以通过描述中提供的联系方式寻求帮助。

    asp.net mvc3 dwz框架 完整的日志管理系统 带数据库

    在ASP.NET MVC3中,可以利用内置的日志接口如`System.Diagnostics.Trace`或`Log4Net`、`NLog`等第三方日志库来实现这一功能。 在该压缩包中,"LogSystem"可能包含了完整的日志管理系统的源代码和数据库配置。日志...

    精通ASP.NET MVC 5.pdf

    日志记录可以集成如log4net、NLog等第三方库,用于跟踪和分析应用程序的行为。 9. **Web API**:ASP.NET MVC 5包含了Web API框架,用于构建RESTful服务,使得移动设备和其他客户端可以方便地与服务器进行数据交换。...

    MVC5中Log4Net写日志配置

    在ASP.NET MVC5框架中,Log4Net是一个广泛使用的日志记录工具,它允许开发者方便地记录应用程序的运行状态、错误信息以及调试信息。本文将详细介绍如何在MVC5项目中配置Log4Net来实现日志功能。 首先,Log4Net是...

    ASP.NET MVC中使用log4net的实现示例

    通过以上步骤,你就成功地在ASP.NET MVC项目中集成了log4net,并能方便地记录和管理日志。在实际开发中,可以根据需求调整配置,例如更改日志输出级别、选择其他类型的appender(如数据库或控制台),或者添加过滤器...

    asp.net mvc后台管理系统 数据库

    3. **Entity Framework**:ASP.NET MVC常与Entity Framework结合使用,这是一个ORM(对象关系映射)工具,允许开发者用C#或VB.NET代码操作数据库,无需编写SQL语句。 4. **模型**:在MVC架构中,模型包含业务逻辑和...

    ASP.NET MVC3官方实例源码

    在ASP.NET MVC中,可以自定义错误页面,使用Elmah或Log4Net等库记录应用程序日志。 通过研究这个音乐商店的实例源码,开发者能够深入了解ASP.NET MVC3的工作原理,学习如何构建一个完整的Web应用,包括数据访问、...

    asp.net MVC和IBatis.net整合demo数据库部分

    为了在ASP.NET MVC中使用Ibatis.net,我们需要进行以下步骤: 1. 配置Ibatis:在`Web.config`文件中配置Ibatis.net,包括数据库连接字符串、SqlMap配置等。 2. 映射对象:创建与数据库表对应的.NET类,并使用XML或...

    ASP.NET MVC例子

    ASP.NET MVC提供了异常过滤器,可以捕获并处理运行时的错误,同时,通过集成日志框架,如Log4Net或NLog,可以记录这些错误以便分析。 通过这个"MVC简单例子",开发者可以学习到如何组织ASP.NET MVC应用的各个部分,...

    Spring.net + MVC + EF + EasyUI + Log4net

    标题 "Spring.net + MVC + EF + EasyUI + Log4net" 涉及到的是一个基于.NET Framework的Web开发框架组合,主要用于构建高效、可扩展的企业级应用。下面将详细介绍这些技术及其相互间的配合。 1. **Spring.NET**:这...

    ASP.NET+MVC+ENTLIB+LOG4NET+IOC

    在"LoggingDemo"这个示例中,很可能包含了如何在ASP.NET MVC应用中集成ENTLIB的日志模块和Log4Net,以及如何使用IOC容器(可能是Unity或Autofac)来管理日志服务的实例。这将帮助开发者理解如何在实际项目中设置和...

    log4net c# .net框架4.0 示例代码

    标题"Log4net C# .NET框架4.0 示例代码"指出,这个压缩包包含的是一个使用C#编程语言,并基于.NET Framework 4.0的示例项目,它主要展示了如何使用Log4net这个日志记录框架。Log4net是Apache的一个开源项目,它为...

    ASP.NET MVC框架留言板2.6.1源码pan321.com

    开发者可能在全局异常过滤器中设置错误处理机制,并使用`log4net`或`NLog`等库记录应用程序日志。 8. **测试**:由于ASP.NET MVC框架鼓励可测试性,项目可能包含单元测试或集成测试,使用如`xUnit`或`NUnit`这样的...

    Asp.net(MVC4)CMS+CRM+OA源码

    日志模块:基于Log4net扩展 服务模块:默认使用引用Bll,可扩张调用Wcf服务,且拦截服务 上传模块:通用upload handler,及缩略图生成方式(按需生成,即时生成,延迟生成) 管道模块:通用HttpModule,用于注入通用...

    Asp.net mvc blog 小程序源码.rar

    10. **错误处理和日志记录**:为了提升用户体验和方便调试,项目可能包含错误处理机制,如全局异常过滤器,以及日志记录框架,如Log4Net或NLog,来记录应用程序的运行情况。 通过研究这个源码,你可以了解到ASP.NET...

    asp.net MVC基础教学

    你可以自定义错误处理中间件来捕获和处理异常,同时使用日志记录库(如NLog或Log4Net)记录应用程序的运行情况。 **14. 测试(Testing)** ASP.NET MVC鼓励测试驱动的开发,控制器和模型可以通过单元测试进行验证,...

    ASP.NET 3.5 MVC 架构与事件源代码第 三部分实战篇

    13. **错误处理和日志记录**:学习如何在ASP.NET MVC中设置全局错误处理,以及如何利用日志记录工具(如log4net)来追踪和调试问题。 14. **部署与性能优化**:了解部署ASP.NET MVC应用的步骤,以及如何进行性能...

    ASP.NET MVC框架开发的DEV控件的文件导入导出.zip

    在这个"ASP.NET MVC框架开发的DEV控件的文件导入导出.zip"压缩包中,主要涉及到的技术点有文件操作、DEV控件的使用以及日志记录工具Log4net。 1. ASP.NET MVC文件操作: 在ASP.NET MVC中,文件上传和下载是常见的...

Global site tag (gtag.js) - Google Analytics