.NET Core 6.0 log4Net 日志配置

发布时间 2023-07-28 22:11:14作者: 可乐加鸡翅

1、 安装Microsoft.Extensions.Logging.Log4Net.AspNetCore 包

2、 创建日志配置文件log4net.config ,并设置文件属性为始终复制

可以去官网下载配置文件, Apache log4net – Apache log4net: Config Example - Apache log4net

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
    <!-- Define some output appenders -->

    <!--Type 表示用那种类型记录日志-->
    <appender name="rollingAppender" type="log4net.Appender.RollingFileAppender">
        <!--表示用文本来记录日志-->

        <file value="log\log.txt" />
        <!--<file value="D:\MyLog1\Onelog.txt" />-->

        <!--追加日志内容-->
        <!--<appendToFile value="false" />-->
        <appendToFile value="true" />

        <!--防止多线程时不能写Log,官方说线程非安全-->
        <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
        <!--最小锁-->

        <!--配置Unicode编码-->
        <Encoding value="UTF-8" />

        <!--是否只写到一个文件里-->
        <param name="StaticLogFileName" value="false" />

        <!--当备份文件时,为文件名加的后缀,这里可以作为每一天的日志分别存储不同的文件-->
        <datePattern value="yyyyMMdd&quot;.txt&quot;" />

        <!--可以为:Once|Size|Date|Composite-->
        <!--Composite为Size和Date的组合-->
        <!--<rollingStyle value="Composite" />-->
        <rollingStyle value="Size" />

        <!--日志最大个数,都是最新的-->
        <!--rollingStyle节点为Size时,只能有value个日志文件-->
        <!--rollingStyle节点为Composite时,每天有value个日志-->
        <maxSizeRollBackups value="2" />

        <!--可用的单位:KB|MB|GB-->
        <maximumFileSize value="2MB" />

        <!--置为true,当前最新日志文件名永远为file节中的名字-->
        <staticLogFileName value="true" />

        <!--过滤器-->

        <!--阻止所有事件被记录-->
        <!--<filter type="log4net.Filter.DenyAllFilter"> </filter>-->

        <!--只有指定等级的日志事件才被记录-->
        <!--<filter type="log4net.Filter.LevelMatchFilter">
        <param value="FATAL" />
      </filter>-->

        <!--日志等级在指定范围内的事件才被记录-->
        <!--<filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="ERROR" />
        <param name="LevelMax" value="FATAL" />
      </filter>-->


        <layout type="log4net.Layout.PatternLayout">
            <!--日志输出格式:时间  日志类型  日志内容-->
            <conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
        </layout>
    </appender>

    <!-- levels: OFF > FATAL > ERROR > WARN > INFO > DEBUG  > ALL -->
    <root>
        <priority value="ALL"/>
        <level value="ALL"/>
        <appender-ref ref="rollingAppender" />
    </root>
</log4net>

 

3、 在Program.cs 文件注入log4Net服务

A、 若日志配置文件log4Net.config放在项目根路径下,就能默认读取。

//注入Log4Net服务
builder.Logging.AddLog4Net();

B、 若日志配置文件log4net.config放不是根路径下,就得在AddLog4Net()后面写上路径

//注入Log4Net服务
builder.Logging.AddLog4Net(”Config/log4net.config“);

 

4、 通过构造函数注入,使用Log4Net

public readonly ILogger<LoginController> _logger;
public LoginController(IUserService userService,ILogger<LoginController> logger) 
{ _userservice
= userService; _logger = logger; } [HttpGet] public async Task<IActionResult> UserLogin([FromQuery]LoginModel model) { User user = new User(); user.Badge = model.Badge; user.Password = model.Password; var result = await _userservice.Login(user.Badge,user.Password); if (result != null) { _logger.LogInformation($"{result.Badge}-{result.CName}在{DateTime.Now.ToString("yyyy-dd-MM HH:mm:ss ")}登入了IPSP系统!"); } return Ok(result); }

 

5、查看日志,打开项目根目录在bin/debug/net6.0目录下可以看到log文件夹,里面有个log.txt文件