ASP.NET WebApi项目框架搭建(四):日志管理之log4net
2021-03-09 07:28
标签:div nuget 类型 doc 好处 rap log文件 type sse 在项目开发的过程中,日志是必不可少的一部分,可以帮我们定位异常,分析错误原因等功能,log4net是.Net下一个非常优秀的开源日志记录组件。log4net记录日志的功能非常强大。它可以将日志分不同的等级,以不同的格式,输出到不同的媒介。本文主要是介绍在前几篇已经创建好的项目里加上日志处理机制 1.使用nuget安装log4net 2.log4net的用法类似下面的代码: 3.运行项目,浏览器调用请求 1.我们用autofac的Module方式去注册log4net组件,项目AutoFac目录下新建Module文件夹,并新建LoggingModule类 这段代码为autofac官网里提供的,参考地址:http://autofaccn.readthedocs.io/en/latest/examples/log4net.html?highlight=module 2.ContainerBuilerCommon下注册module 3.控制器通过构造函数注入Ilog 4.新建get请求 5.现在编译程序后用postman工具的get方法访问接口:http://localhost:xxx/api/autolog4,程序是运行正常的 。但现在日志即没有写入到某个文件、数据库或是发送到邮件里,也没有输出到控制台上。这就是log4net的设计的好处,在程序里你只管做日志的处理,如调用ILog的Debug()、Info()、Warn()、Error()、Fatal(),至于日志是由什么机制去处理(如写入文件,写入数据库等)是由另一个流程来控制,即log4net的配置文件。如果程序里没有log4net的配置文件,程序也能正常运行。 1.新建Log4net.config,代码如下 2.properties下的AssemblyInfo.cs文件里添加以下代码: 3.运行程序,调用日志请求,log4net会在项目主目录下的log文件夹生成日志文件 DEBUG日志: ERROR日志: ASP.NET WebApi项目框架搭建(四):日志管理之log4net 标签:div nuget 类型 doc 好处 rap log文件 type sse 原文地址:https://www.cnblogs.com/huguodong/p/12754808.html一、前言
二、安装并使用log4net
[Route("log4")]
[HttpGet]
public IHttpActionResult Log()
{
// 通过LogManager的静态方法GetLogger生成一个Ilog对象
ILog log = LogManager.GetLogger(typeof(IndexController)); // 下面是日志处理
log.Debug("测试debug", new Exception("debug异常"));
log.Info("测试Info", new Exception("Info异常"));
log.Warn("测试Warn", new Exception("Warn异常"));
log.Error("测试Error", new Exception("Error异常"));
log.Fatal("测试Fatal", new Exception("Fatal异常"));
return Ok("已经写入日志");
}
三、通过autofac解耦Ilog对象
public class LoggingModule : Autofac.Module
{
private static void InjectLoggerProperties(object instance)
{
var instanceType = instance.GetType();
// Get all the injectable properties to set.
// If you wanted to ensure the properties were only UNSET properties,
// here‘s where you‘d do it.
var properties = instanceType
.GetProperties(BindingFlags.Public | BindingFlags.Instance)
.Where(p => p.PropertyType == typeof(ILog) && p.CanWrite && p.GetIndexParameters().Length == 0);
// Set the properties located.
foreach (var propToSet in properties)
{
propToSet.SetValue(instance, LogManager.GetLogger(instanceType), null);
}
}
private static void OnComponentPreparing(object sender, PreparingEventArgs e)
{
e.Parameters = e.Parameters.Union(
new[]
{
new ResolvedParameter(
(p, i) => p.ParameterType == typeof(ILog),
(p, i) => LogManager.GetLogger(p.Member.DeclaringType)
),
});
}
protected override void AttachToComponentRegistration(IComponentRegistry componentRegistry, IComponentRegistration registration)
{
registration.Preparing += OnComponentPreparing;
// Handle properties.
registration.Activated += (sender, e) => InjectLoggerProperties(e.Instance);
}
}
public static IContainer GetWebApiContainer()
{
var builder = new ContainerBuilder();
// 注册webapi的所有控制器
builder.RegisterApiControllers(Assembly.GetExecutingAssembly());
// 注册一个用于测试的组件。
builder.RegisterType
private ILog _log;
public IndexController(ILog log, Person person)
{
_person = person;
_log = log;
}
[Route("autolog4")]
[HttpGet]
public IHttpActionResult AutoLog()
{
// 通过LogManager的静态方法GetLogger生成一个Ilog对象
_log.Debug("测试debug", new Exception("debug异常"));
_log.Info("测试Info", new Exception("Info异常"));
_log.Warn("测试Warn", new Exception("Warn异常"));
_log.Error("测试Error", new Exception("Error异常"));
_log.Fatal("测试Fatal", new Exception("Fatal异常"));
return Ok("已经写入日志");
}
四、配置Log4net
"1.0" encoding="utf-8"?>
[assembly: XmlConfigurator(Watch = true, ConfigFile = "Log4Net.config")]
文章标题:ASP.NET WebApi项目框架搭建(四):日志管理之log4net
文章链接:http://soscw.com/index.php/essay/62184.html