本文将介绍如何整合log4net框架并如何使用该框架来进行日志的管理。
框架引用
首先我们必须在Web项目下添加框架的引用。右键点击Web项目下的引用,选择管理Nuget程序包。
搜索log4gnet,安装到项目中。
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的异常。
启动项目: