日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

.NET Core log4net 使用(转贴)

發布時間:2025/3/15 asp.net 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .NET Core log4net 使用(转贴) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

log4net?.NET Core 版使用,log4net 2.0.7版發布也有一段時間了,從2.0.6 版開始就已經支持.NET Core。

之前有介紹NLog .NET Core版的使用,ASP.NET Core 開發-Logging 使用NLog 寫日志文件。

ASP.NET Core已經內置了日志支持,可以輕松輸出到控制臺。使用log4net 將日志寫入到文件及輸出控制臺。

?

.NET Core項目使用

新建一個 .NET Core 項目,選擇控制臺應用程序

添加引用:

Install-Package log4net

?

使用簡單配置,將日志輸出至控制臺,跟之前.NET 版本略微有些區別,需要指定Repository 。

public static void Main(string[] args)

? ? ? ? {

? ? ? ? ? ? ILoggerRepository repository = LogManager.CreateRepository("NETCoreRepository");

? ? ? ? ? ? // 默認簡單配置,輸出至控制臺

? ? ? ? ? ? BasicConfigurator.Configure(repository);

? ? ? ? ? ? ILog log = LogManager.GetLogger(repository.Name,"NETCorelog4net");

?

? ? ? ? ? ? log.Info("NETCorelog4net log");

? ? ? ? ? ? log.Info("test log");

? ? ? ? ? ? log.Error("error");

? ? ? ? ? ? log.Info("linezero");

? ? ? ? ? ? Console.ReadKey();

? ? ? ? }

運行程序顯示如下:

?

下面增加配置,讓其輸出至文件。

在項目中添加一個配置文件,這里添加一個log4net.config ,內容如下:

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

? <!-- This section contains the log4net configuration settings -->

? <log4net>

? ? <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">

? ? ? <layout type="log4net.Layout.PatternLayout" value="%date [%thread] %-5level %logger - %message%newline" />

? ? </appender>

? ??

? ? <appender name="FileAppender" type="log4net.Appender.FileAppender">

? ? ? <file value="log-file.log" />

? ? ? <appendToFile value="true" />

? ? ? <layout type="log4net.Layout.PatternLayout">

? ? ? ? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />

? ? ? </layout>

? ? </appender>

?

? ? <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">

? ? ? <file value="logfile/" />

? ? ? <appendToFile value="true" />

? ? ? <rollingStyle value="Composite" />

? ? ? <staticLogFileName value="false" />

? ? ? <datePattern value="yyyyMMdd'.log'" />

? ? ? <maxSizeRollBackups value="10" />

? ? ? <maximumFileSize value="1MB" />

? ? ? <layout type="log4net.Layout.PatternLayout">

? ? ? ? <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />

? ? ? </layout>

? ? </appender>

?

? ? <!-- Setup the root category, add the appenders and set the default level -->

? ? <root>

? ? ? <level value="ALL" />

? ? ? <appender-ref ref="ConsoleAppender" />

? ? ? <appender-ref ref="FileAppender" />

? ? ? <appender-ref ref="RollingLogFileAppender" />

? ? </root>

?

? </log4net>

</configuration>

這里定義了三個?Appender,都會起作用,然后日志級別ALL 所有的日志都會記錄。

更改Program.cs 代碼如下:

public static void Main(string[] args)

? ? ? ? {

? ? ? ? ? ? ILoggerRepository repository = LogManager.CreateRepository("NETCoreRepository");

? ? ? ? ? ? XmlConfigurator.Configure(repository, new FileInfo("log4net.config"));

? ? ? ? ? ? ILog log = LogManager.GetLogger(repository.Name,"NETCorelog4net");

?

? ? ? ? ? ? log.Info("NETCorelog4net log");

? ? ? ? ? ? log.Info("test log");

? ? ? ? ? ? log.Error("error");

? ? ? ? ? ? log.Info("linezero");

? ? ? ? ? ? Console.ReadKey();

? ? ? ? }

加了指定配置文件。運行程序會生成一個文件夾和一個文件,因為重新定義了ConsoleAppender,控制臺輸出也有所不同。

?

ASP.NET Core項目使用

在ASP.NET Core 使用也是一樣,可以在Program.cs或Startup.cs 中指定Repository,然后控制器或中間件中獲取對象使用。

以下代碼是在Startup 構造函數中初始化log4net

public class Startup

? ? {

? ? ? ? public static ILoggerRepository repository { get; set; }

? ? ? ? public Startup(IHostingEnvironment env)

? ? ? ? {

? ? ? ? ? ? var builder = new ConfigurationBuilder()

? ? ? ? ? ? ? ? .SetBasePath(env.ContentRootPath)

? ? ? ? ? ? ? ? .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)

? ? ? ? ? ? ? ? .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)

? ? ? ? ? ? ? ? .AddEnvironmentVariables();

? ? ? ? ? ? Configuration = builder.Build();

? ? ? ? ? ? repository = LogManager.CreateRepository("NETCoreRepository");

? ? ? ? ? ? XmlConfigurator.Configure(repository, new FileInfo("log4net.config"));

? ? ? ? }

然后在Configure 中加了一個記錄日志

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory){ var log = LogManager.GetLogger(repository.Name,typeof(Startup));log.Info("test");

?

在HomeController 也增加了:

private ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HomeController));

? ? ? ? public IActionResult Index()

? ? ? ? {

? ? ? ? ? ? log.Info("index view");

? ? ? ? ? ? log.Error("Controller Error");

? ? ? ? ? ? return View();

? ? ? ? }

運行應用結果如下,然后對應的文件會有日志記錄。

?

?

對于輸出中文亂碼,需要增加編碼引用,以及代碼。NLog 那篇文章有介紹。寫到日志文件是沒有問題的。

?

參考文檔:

http://logging.apache.org/log4net/release/manual/configuration.html

http://logging.apache.org/log4net/release/config-examples.html

原文地址:http://www.cnblogs.com/linezero/p/log4net.html

轉載于:https://www.cnblogs.com/ppkkqq/p/6477612.html

總結

以上是生活随笔為你收集整理的.NET Core log4net 使用(转贴)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲区欧美 | 中文字幕3区 | 在线观看日韩一区二区 | 亚洲熟伦熟女新五十路熟妇 | 爱爱免费视频网站 | 国产精品综合视频 | 久久人人爽爽人人爽人人片av | 学生调教贱奴丨vk | 久久久精品视频网站 | 天天干狠狠插 | 污污视频免费看 | 美脚の诱脚舐め脚 | 一区二区在线精品 | 婷婷综合视频 | 日日夜夜国产 | 久久性| 欧美日韩国产精品一区二区 | 久久伊人久久 | 日本三级视频在线播放 | 日韩视频免费观看 | 欧美精品久久久久久久久久 | 一区二区高潮 | 亚洲精品在线免费播放 | 色婷婷狠狠| 久久99精品国产91久久来源 | 99热6这里只有精品 三级av在线免费观看 | 免费观看理伦片在线播放视频软件 | 婷婷av在线 | 美女日批在线观看 | 一区二区三区激情 | 波多野结衣av电影 | 日韩人妻精品一区二区 | 九九在线观看视频 | 九九欧美 | 亚洲无吗视频 | 99热亚洲精品 | 美女福利在线视频 | 明星双性精跪趴灌满h | 九九热免费在线 | 亚洲一区二区免费看 | 三级a做爰全过程 | 亚洲精品视频一区二区 | 国产精品国产三级国产普通话对白 | 欧美一区二区三区的 | 中文字幕+乱码+中文字幕明步 | 少妇淫片 | 一级a性色生活片久久无 | 尤物国产视频 | 欧美色图亚洲自拍 | 国产99999 | 久久久久亚洲国产 | 国产精品无码成人片 | 色呦呦官网 | 久久黄色片 | 日韩亚洲第一页 | 黄色av中文字幕 | av官网在线 | 在线看免费 | 日韩高清二区 | 亚洲免费观看高清在线观看 | 欧美一区二区最爽乱淫视频免费看 | 日韩午夜伦| 国产20页 | 亚洲女人的天堂 | 老师的肉丝玉足夹茎 | 少妇29p| 中文字幕一区二区久久人妻 | 午夜精产品一区二区在线观看的 | 精品国产精品国产偷麻豆 | 久久老熟女一区二区三区 | 欧洲女同同性吃奶 | 三级黄色网 | 成人69视频| 黄色香蕉网站 | 国产伦精品一区二区三区免费迷 | 欧美一区二 | 国产五月| 人妻一区二区视频 | 亚洲最大的网站 | 国产精品91久久久 | 欧美在线播放一区二区 | 波多野结衣 在线 | 99riav1国产精品视频 | 日韩福利在线 | 有机z中国电影免费观看 | 99视频这里有精品 | 免费看黄色一级视频 | 中文字幕777| 狠狠狠狠狠狠狠干 | 91综合国产 | 欧美色乱 | 涩涩网站在线 | caoporn视频在线 | 女人高潮特级毛片 | h视频免费在线观看 | 国产精品夫妻 | 黄色大全免费观看 | 激情第一页 | 久久手机视频 |