您现在的位置是:网站首页> 编程资料编程资料
详解log4net的使用_实用技巧_
2023-05-24
433人已围观
简介 详解log4net的使用_实用技巧_
程序中只需要引用log4net.dll文件即可
配置的引用
log4net.Config.XmlConfigurator.Configure();
首先添加以上代码。
CS程序:在Main方法中添加;
BS程序:Application_Start方法中添加;
或是两者都可以在AssemblyInfo.cs(Properties中)文件里添加以下的语句:
//设置独立配置文件,log4net.config [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config" , Watch = true )] //或是默认的配置文件 [assembly: log4net.Config.XmlConfigurator(Watch = true )] (配置在web.config文件中)
详细配置
log4net,可以把日志输出到控制台程序,文件,数据库、邮件,下面贴出四个输出的配置代码,其余如window日志等输出不做阐述。
布局、格式字符说明:
%p:输出日志信息的优先级,即DEBUG,INFO,WARN,ERROR,FATAL。
%d:输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:输出自应用程序启动到输出该log信息耗费的毫秒数。
%t:输出产生该日志事件的线程名。
%l:输出日志事件的发生位置,相当于%c.%M(%F:%L)的组合,包括类全名、方法、文件名以及在代码中的行数。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:输出日志信息所属的类目,通常就是所在类的全名。
%M:输出产生日志信息的方法名。
%F:输出日志消息产生时所在的文件名称。
%L::输出代码中的行号。
%m::输出代码中指定的具体日志信息。
%n:输出一个回车换行符,Windows平台为"\r\n",Unix平台为"\n"。
%x:输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
%%:输出一个"%"字符。
另外,还可以在%与格式字符之间加上修饰符来控制其最小长度、最大长度、和文本的对齐方式。如:
1)%20c:指定输出category的名称,最小的长度是20,如果category的名称长度小于20的话,默认的情况下右对齐。
2)%-20c:"-"号表示左对齐。
3)%.30c:指定输出category的名称,最大的长度是30,如果category的名称长度大于30的话,就会将左边多出的字符截掉,但小于30的话也不会补空格。
自定义数据库插入字段(源自网络收集、整理)
1.先定义一个LogData类:
namespace log4_Test.Log4netExpand { public class LogData { /// /// 日志描述信息 /// public string Description { get; set; } /// /// 日志描述信息 /// public string ObjType { get; set; } } }2.Layout扩展类
namespace log4_Test.Log4netExpand { public class ExpandLayout : PatternLayout { public ExpandLayout() { this.AddConverter("property", typeof(MyMessagePatternConverter)); } } }3.MyMessagePatternConverter 类
namespace log4_Test.Log4netExpand { public class MyMessagePatternConverter: PatternLayoutConverter { protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent) { if (Option != null) { // Write the value for the specified key WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent)); } else { // Write all the key value pairs WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties()); } } /// /// 通过反射获取传入的日志对象的某个属性的值 /// /// /// private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent) { object propertyValue = string.Empty; PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property); if (propertyInfo != null) { propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null); } return propertyValue; } } }4.使用代码如下:
public class Program { static void Main(string[] args) { //能看到是那个类输出 ILog logger = log4net.LogManager.GetLogger(typeof(Program)); logger.Info(new LogData { Description="123", ObjType="123"}) logger.Info("消息11111111111111111111111111111"); logger.Warn("警告"); logger.Error("异常"); logger.Fatal("错误"); } }以上所述是小编给大家介绍的log4net的使用详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
相关内容
- 详解.net core日记记录_实用技巧_
- Asp.Net Core Web应用程序—探索_实用技巧_
- Visual Studio 2015下载和安装图文教程_实用技巧_
- 详解asp.net core重新加载应用配置_实用技巧_
- 详解.NET Core使用Quartz执行调度任务进阶_实用技巧_
- .NET CORE中使用AutoMapper进行对象映射的方法_实用技巧_
- 详解使用DotNet CLI创建自定义的WPF项目模板_实用技巧_
- 打造自己的.NET Core项目模板_实用技巧_
- 浅谈.net core 注入中的三种模式:Singleton、Scoped 和 Transient_实用技巧_
- .net core如何在网络高并发下提高JSON的处理效率详解_实用技巧_
