.net core整合log4net的解決方案
概述
log4net是.Net下一個非常優(yōu)秀的開源日志記錄組件。log4net記錄日志的功能非常強(qiáng)大。它可以將日志分不同的等級,以不同的格式,輸出到不同的媒介。
背景
前兩天,曾經(jīng)的一個同事咨詢我,怎樣將log4net以中間件的形式整合到core里邊去。我不假思索的回答,這種問題應(yīng)該有人做過吧,他說沒有。于是,我去博客園搜了下,發(fā)現(xiàn)還真沒有,全部都是傳統(tǒng).NET那一套,直接LogManager.GetLogger,于是趁著周末有時間,決定調(diào)研下這個問題。去巨硬官網(wǎng)快速瀏覽了下,擴(kuò)展第三方日志的核心就在于兩個接口:ILogger和ILoggerProvider。于是建好解決方案,刷刷刷實現(xiàn)這兩個接口,實現(xiàn)差不多了查相關(guān)資料時,猛然發(fā)現(xiàn),臥槽,已經(jīng)有國外同仁實現(xiàn)過了,我尼瑪?shù)男量鄬懓胩?,這下徹底垮了。。。
切換四路
本著偷懶、鄙視瞎造輪子/裝逼的心態(tài), 直接把解決方案切換到開源實現(xiàn)。實際上順便看了下第三方實現(xiàn)源碼,四路也是一致的,實現(xiàn)那兩個接口。
解決方案如下:
包引用如下:
最上邊的不多說,第二個別問我,第三個就是core整合log4net的主角。關(guān)于這個,得特別說明下,最新版本是2.2.1,但我并沒有引用最新的,而是2.1.0,因為目前有些第三方包最新版本引用的原子包是最新的,而上邊第二個鬼東東Microsoft.AspNetCore.App這個框架包底層的原子包卻并不是,所以如果引用最新的第三方包,很可能會報某個原子包依賴版本不對的錯誤。解決方案有二:1、哪個包報錯,你單獨安裝哪個原子包的最新版本;2、切換第三方包的版本到較次,找到能夠兼容當(dāng)前Microsoft.AspNetCore.App的實現(xiàn)。解決方案1的問題是,你更新了這個原子包,它的依賴包又出錯,你更新了它的依賴的依賴,它的依賴的依賴的依賴又出錯。。。所以,方便起見,我直接用了Microsoft.Extensions.Logging.Log4Net.AspNetCore的較低版本。
log4net.config不再截圖或上代碼,跟以前的德行沒啥兩樣。
接下來,注冊log4net:
圖中,前兩行的作用是過濾掉System和Microsoft開頭的命名空間下的組件產(chǎn)生的警告級別一下的日志,實際上主要就是一些框架性日志。第三行便是注冊log4net中間件。
接下來新建控制器,注入日志實踐下效果:
上圖兩個紅框,上邊一個是構(gòu)造器注入日志接口,下邊是調(diào)用日志組件記錄日志。
好,接下來我們?nèi)タ纯聪到y(tǒng)產(chǎn)生的日志,先調(diào)用:
控制臺窗口:
OK,日志已經(jīng)輸出成功,接下來,我們看關(guān)鍵性的輸出到文件:
看到?jīng)]有,日志已經(jīng)成功經(jīng)由log4net輸出到文件。
總結(jié)
感覺沒什么好總結(jié)的,.net core提供的擴(kuò)展已經(jīng)很開放了,雖然log4net目前比較操蛋,但這對咱大部分.NET開發(fā)者來說應(yīng)該都不是事兒。
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- ASP.NET Core使用Log4net實現(xiàn)日志記錄功能
- .net項目使用日志框架log4net
- .Net?Core3.0?WebApi?項目框架搭建之使用Serilog替換掉Log4j
- .NET6在WebApi中使用日志組件log4net
- asp.net中使用log4net詳解
- 在.NET?6中使用日志組件log4net的方法
- .NET Core下使用Log4Net記錄日志的方法步驟
- ASP.NET MVC中使用log4net的實現(xiàn)示例
- .net簡單使用Log4net的方法(多個日志配置文件)
- asp.net log4net的使用方法
- asp.net中Log4.net的工具類helper
相關(guān)文章
ASP.NET2.0中用Gridview控件操作數(shù)據(jù)的代碼
在ASP.NET 2.0中,加入了許多新的功能和控件,相比asp.net 1.0/1.1,在各方面都有了很大的提高2012-10-10增加asp.net應(yīng)用程序性能的20種方法(簡單有效)
增加asp.net應(yīng)用程序性能的20種方法小結(jié),需要的朋友可以參考下,對于服務(wù)器也需要一些設(shè)置。2010-01-01利用ASP.NET MVC和Bootstrap快速搭建個人博客之后臺dataTable數(shù)據(jù)列表
jQuery dataTables 插件是一個優(yōu)秀的表格插件,應(yīng)用非常廣泛,本文給大家介紹利用ASP.NET MVC和Bootstrap快速搭建個人博客之后臺dataTable數(shù)據(jù)列表,非常不錯,具有參考借鑒價值,感興趣的朋友一起看下吧2016-07-07