侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

详解log4net的使用

技术  /  管理员 发布于 7年前   195

程序中只需要引用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日志等输出不做阐述。

<?xml version="1.0" encoding="utf-8" ?><configuration> <!--首先加入configSections配置节点--> <configSections>  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/> </configSections> <log4net><br>  <root>   <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) -->   <!--限制日志记录级别-->   <level value="all" />   <!--将日志输出到文件-->   <appender-ref ref="FileAppender"/>   <!--将日志输出到应用程序控制台-->   <appender-ref ref="ConsoleAppender"/>   <!--将日志写到邮件中-->   <!--<appender-ref ref="LogSmtpAppender"/>-->   <!--将日志记录到数据库中。可以采用SQL和存储过程两种方式-->   <appender-ref ref="AdoNetAppender"/>   <!--可以同时设置多个输出对象,没用到可以注释-->   <!--将日志写到local syslog service (仅用于UNIX环境下)。-->   <!--<appender-ref ref="LocalSyslogAppender"/>-->  </root><br>  <!--发邮件-->  <appender name="LogSmtpAppender" type="log4net.Appender.SmtpAppender">   <authentication value="Basic" />   <!--接受邮件的邮箱-->   <to value="[email protected]" />   <!--发送邮件的邮箱-->   <from value="[email protected]" />   <!--发送邮件的邮箱-->   <username value="[email protected]" />   <!--发送邮件的邮箱密码-->   <password value="123456" />   <!--标题-->   <subject value="XXX应用错误日志消息" />   <!--smtp.qq.com-->   <smtpHost value="smtp.126.com" />   <bufferSize value="2048" />   <!--超长部分是否丢弃-->   <lossy value="true" />   <!--日志级别 大于 WARN 的才发邮件-->   <evaluator type="log4net.Core.LevelEvaluator">    <threshold value="ERROR"/>   </evaluator>   <layout type="log4net.Layout.PatternLayout">    <conversionPattern value=" %level :: %message %newlineLogger: %logger%newline Date: %date%newline" />   </layout>  </appender><br>  <!-- 控制台日志 -->  <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">   <layout type="log4net.Layout.PatternLayout">    <conversionPattern value="%n%d{yyyy-MM-dd HH:mm:ss} %m%n" />   </layout>   <!--指定范围内的等级才可以被记录-->   <!--<filter type="log4net.Filter.LevelRangeFilter">    <param name="LevelMin" value="Info" />    <param name="LevelMax" value="Fatal" />   </filter>-->  </appender >   <!--指定日记记录方式,以滚动文件的方式(文件记录)-->  <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">   <!--日志路径-->   <param name= "File" value= "log/"/>   <!--是否是向文件中追加日志-->   <param name= "AppendToFile" value= "true"/>   <!--log保留天数-->   <param name= "MaxSizeRollBackups" value= "10"/>   <!--每个文件最大1M-->   <param name="maximumFileSize" value="1MB" />   <!--日志文件名是否是固定不变的-->   <param name= "StaticLogFileName" value= "false"/>   <!--日志文件名格式为:2008-08-31.log-->   <param name= "DatePattern" value= "yyyy-MM-dd".log""/>   <!--日志根据日期滚动-->   <param name= "RollingStyle" value= "Date"/>   <!--布局-->   <layout type="log4net.Layout.PatternLayout">    <param name="ConversionPattern" value="%n记录时间:%d{yyyy-MM-dd HH:mm:ss} 线程名:[%t] 级别:%p 类名:%c 信息:%m%n" />    <param name="Header" value="----------------------------------------------------------- "/>   </layout>  </appender><br>  <!--数据库日记-->  <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">   <!--设置为1方便查看结果,处于性能考虑这里的值应该略大一点,官方默认值是100,BufferSize为缓冲区大小,只有日志记录超设定值才会一块写入到数据库-->   <bufferSize value="1" />   <!--sqlserver 引用-->   <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />   <!--连接数据库字符串-->   <connectionString value="data source=.;initial catalog=test;integrated security=false;persist security info=True;User ID=sa;Password=sqlserver;" />   <!--插入到表Log-->   <commandText value="INSERT INTO LogTest ([Date],[Level],[Logger],[Message],[Exception],[Description],[ObjType]) VALUES (@log_date,@log_level, @logger, @message, @exception,@Description,@ObjType)" />   <!--所有参数-->   <parameter>    <parameterName value="@log_date" />    <dbType value="DateTime" />    <layout type="log4net.Layout.RawTimeStampLayout" />   </parameter>   <parameter>    <parameterName value="@log_level" />    <dbType value="String" />    <size value="50" />    <layout type="log4net.Layout.PatternLayout">     <conversionPattern value="%level" />    </layout>   </parameter>   <!--类所在位置-->   <parameter>    <parameterName value="@logger" />    <dbType value="String" />    <size value="255" />    <layout type="log4net.Layout.PatternLayout">     <conversionPattern value="%logger" />    </layout>   </parameter>   <parameter>    <parameterName value="@message" />    <dbType value="String" />    <size value="4000" />    <layout type="log4net.Layout.PatternLayout">     <conversionPattern value="%message" />    </layout>   </parameter>   <parameter>    <parameterName value="@exception" />    <dbType value="String" />    <size value="2000" />    <layout type="log4net.Layout.ExceptionLayout" />   </parameter>   <!--自定义输入字段-->   <parameter>    <parameterName value = "@Description"/>    <dbType value = "String"/>    <size value = "50"/>    <layout type = "log4_Test.Log4netExpand.ExpandLayout">    <conversionPattern value = "%property{Description}"/>    </layout>   </parameter>   <parameter>    <parameterName value = "@ObjType"/>    <dbType value = "String"/>    <size value = "50"/>    <layout type = "log4_Test.Log4netExpand.ExpandLayout">     <conversionPattern value = "%property{ObjType}"/>    </layout>   </parameter>  </appender>  </log4net></configuration>

 <layout type = "log4_Test.Log4netExpand.ExpandLayout"> 中的log4_Test.Log4netExpand 为命名空间

布局、格式字符说明:

%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  {    /// <summary>    /// 日志描述信息    /// </summary>    public string Description { get; set; }    /// <summary>    /// 日志描述信息    /// </summary>    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());      }    }    /// <summary>    /// 通过反射获取传入的日志对象的某个属性的值    /// </summary>    /// <param name="property"></param>    /// <returns></returns>    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的使用详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!


  • 上一条:
    composer安装的方法步骤(图文)
    下一条:
    Visual Studio 2015下载和安装图文教程
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 2024.07.09日OpenAI将终止对中国等国家和地区API服务(0个评论)
    • 2024/6/9最新免费公益节点SSR/V2ray/Shadowrocket/Clash节点分享|科学上网|免费梯子(0个评论)
    • 国外服务器实现api.openai.com反代nginx配置(0个评论)
    • 2024/4/28最新免费公益节点SSR/V2ray/Shadowrocket/Clash节点分享|科学上网|免费梯子(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2017-09
    • 2018-01
    • 2018-07
    • 2018-08
    • 2018-09
    • 2018-12
    • 2019-01
    • 2019-02
    • 2019-03
    • 2019-04
    • 2019-05
    • 2019-06
    • 2019-07
    • 2019-08
    • 2019-09
    • 2019-10
    • 2019-11
    • 2019-12
    • 2020-01
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-12
    • 2024-02
    • 2024-04
    • 2024-05
    • 2024-06
    • 2025-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客