天天看点

ASP.NET MVC5框架搭建4--log4net框架整合框架引用log4net配置异常拦截测试

本文将介绍如何整合log4net框架并如何使用该框架来进行日志的管理。

框架引用

首先我们必须在Web项目下添加框架的引用。右键点击Web项目下的引用,选择管理Nuget程序包。

ASP.NET MVC5框架搭建4--log4net框架整合框架引用log4net配置异常拦截测试

搜索log4gnet,安装到项目中。

ASP.NET MVC5框架搭建4--log4net框架整合框架引用log4net配置异常拦截测试

log4net配置

在Web项目根目录下新建log4net.config配置文件,具体配置信息入下:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <log4net>    
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout" value="%date [%thread] %-5level %logger - %message%newline" />
    </appender>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="log/" />
      <appendToFile value="true" />
      <rollingStyle value="Composite" />
      <staticLogFileName value="false" />
      <datePattern value="yyyyMMdd'.log'" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="1MB" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message %newline" />
      </layout>
    </appender>
    <root>
      <level value="ALL" />
      <appender-ref ref="ConsoleAppender" />
      <appender-ref ref="RollingLogFileAppender" />
    </root>
  </log4net>
</configuration>
           

然后打开properties/AssemblyInfo文件,在文件末尾添加下面语句,告诉程序加载配置文件,注意文件名一致:

异常拦截

本项目使用Application_Error来进行整个项目的异常处理,如果要使用Application_Error首先要关闭全局异常的拦截,以下方法二选一:

在Web.config下system.web节点添加以下内容,关闭自定义异常:

打开golbal文件,注释掉全局过滤器:

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();
    //FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);

    // autofac注册
    AutofacConfig.Register();
}
           

最后打开golbal文件添加log变量和Application_Error方法,修改成以下内容:

using System;
using System.Web.Mvc;
using System.Web.Optimization;
using System.Web.Routing;
using MVC5Demo.Web.App_Start;

namespace MVC5Demo.Web
{
    public class MvcApplication : System.Web.HttpApplication
    {
    	// 添加log变量
        private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

        protected void Application_Start()
        {
            AreaRegistration.RegisterAllAreas();
            //FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
            RouteConfig.RegisterRoutes(RouteTable.Routes);
            BundleConfig.RegisterBundles(BundleTable.Bundles);

            // autofac注册
            AutofacConfig.Register();
        }

        protected void Application_Error(Object sender, EventArgs e)
        {
            var lastError = Server.GetLastError();
            log.Error(lastError.Message, lastError);
            Response.WriteFile("~/Views/Shared/Error.cshtml");
            Server.ClearError();
        }
    }
}
           

测试

到目前为止,log4net已整合完毕,下面让我们来测试一下。

打开Controllers/HomeController文件,对Index函数进行代码改写,制造一个异常:

public ActionResult Index()
{
    var a = 0;
    var b = 10 / a;
    ViewBag.msg = testService.GetItems();
    return View();
}
           

该函数会报一个尝试除以0的异常。

启动项目:

ASP.NET MVC5框架搭建4--log4net框架整合框架引用log4net配置异常拦截测试
ASP.NET MVC5框架搭建4--log4net框架整合框架引用log4net配置异常拦截测试

继续阅读