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".txt"" /> <!--可以为: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文件
标签:log4Net,Core,log4net,--,result,6.0,日志,logger,user From: https://www.cnblogs.com/xjxue/p/17589013.html