ASP.NET Core使用NLog輸出日志記錄
ASP.NET Core 中的日志記錄
https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/logging/?view=aspnetcore-2.1
日志級別:Trace -》Debug-》 Information -》Warning-》 Error-》 Critical
級別包含范圍由大到小 ,如 Trace 就包含了所有信息。
基礎用法
public class HomeController : Controller { private readonly ILogger _logger; public HomeController(ILogger<HomeController> logger) { _logger = logger; } public IActionResult Index() { _logger.LogInformation("你訪問了首頁"); _logger.LogWarning("警告信息"); _logger.LogError("錯誤信息"); return View(); } }
日志事件 ID
public class LoggingEvents { public const int GenerateItems = 1000; public const int ListItems = 1001; public const int GetItem = 1002; public const int InsertItem = 1003; public const int UpdateItem = 1004; public const int DeleteItem = 1005; public const int GetItemNotFound = 4000; public const int UpdateItemNotFound = 4001; }
_logger.LogWarning(LoggingEvents.GetItemNotFound, "GetById({ID}) NOT FOUND", 100);
結果:
warn: TodoApi.Controllers.TodoController[4000]
GetById(100) NOT FOUND
NLog 輸出到文件
https://github.com/NLog/NLog.web/wiki
asp.net core 2
https://github.com/NLog/NLog.Web/wiki/Getting-started-with-ASP.NET-Core-2
Create a nlog.config
file.
<?xml version="1.0" encoding="utf-8" ?> <nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" autoReload="true" internalLogLevel="info" internalLogFile="c:\temp\internal-nlog.txt"> <!-- enable asp.net core layout renderers --> <extensions> <add assembly="NLog.Web.AspNetCore"/> </extensions> <!-- the targets to write to --> <targets> <!-- write logs to file --> <target xsi:type="File" name="allfile" fileName="c:\temp\nlog-all-${shortdate}.log" layout="${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}" /> <!-- another file log, only own logs. Uses some ASP.NET core renderers --> <target xsi:type="File" name="ownFile-web" fileName="c:\temp\nlog-own-${shortdate}.log" layout="${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}" /> </targets> <!-- rules to map from logger name to target --> <rules> <!--All logs, including from Microsoft--> <logger name="*" minlevel="Trace" writeTo="allfile" /> <!--Skip non-critical Microsoft logs and so log only own logs--> <logger name="Microsoft.*" maxLevel="Info" final="true" /> <!-- BlackHole without writeTo --> <logger name="*" minlevel="Trace" writeTo="ownFile-web" /> </rules> </nlog>
復制到輸出目錄:始終復制
Update program.cs
這里 nlog-all-.log 是記錄所有日志,nlog-own-.log 記錄跳過Microsoft 開頭的類庫輸出的相關信息,剩下的信息。
參考:http://chabaoo.cn/article/142992.htm
到此這篇關于ASP.NET Core使用NLog輸出日志記錄的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
.NET調(diào)用控制臺下生成的exe文件,傳參及獲取返回參數(shù)的思路及代碼
.NET調(diào)用控制臺下生成的exe文件,傳參及獲取返回參數(shù)的思路及代碼,需要的朋友可以參考一下2013-06-06前臺JS(jquery ajax)調(diào)用后臺方法實現(xiàn)無刷新級聯(lián)菜單示例
前臺用AJAX直接調(diào)用后臺方法,老有人發(fā)帖提問,沒事做個示例詳細介紹一下,感興趣的朋友可以參考下2013-01-01Asp.Net Core中基于Session的身份驗證的實現(xiàn)
這篇文章主要介紹了Asp.Net Core中基于Session的身份驗證的實現(xiàn)2018-09-09asp.net實現(xiàn)生成靜態(tài)頁并添加鏈接的方法
這篇文章主要介紹了asp.net實現(xiàn)生成靜態(tài)頁并添加鏈接的方法,非常實用的功能,需要的朋友可以參考下2014-07-07