.net core 雜記:日記記錄

来源:https://www.cnblogs.com/qiuguochao/archive/2019/04/24/10765614.html
-Advertisement-
Play Games

ASP.NET Core 有內置的log組件,遺憾的是看了微軟官方文檔,貌似無法直接將日誌存於文件或資料庫,只能由自己實現或引用第三方日誌組件。 以下為Nlog和log4net的使用記錄 Nlog使用 搜索添加Nuget包 搜索添加Nuget包 新建一個xml文件,並改名為nlog.config 新 ...


ASP.NET Core 有內置的log組件,遺憾的是看了微軟官方文檔,貌似無法直接將日誌存於文件或資料庫,只能由自己實現或引用第三方日誌組件。

以下為Nlog和log4net的使用記錄

Nlog使用

  •  搜索添加Nuget包

Nlog
Nlog.Web.AspNetCore
  • 新建一個xml文件,並改名為nlog.config

XML內容如下(可配置日誌目錄名稱、輸出格式):

<?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="Warn"
      internalLogFile="internal-nlog.txt">

  <!--define various log targets-->
  <targets>
<!--write logs to file--> <target xsi:type="File" name="allfile" fileName="Logs/service-${shortdate}.log" layout="${longdate}|${logger}|${uppercase:${level}}|${message} ${exception}" />
</targets>
<rules> <!--All logs, including from Microsoft--> <logger name="*" minlevel="Trace" writeTo="allfile" /> </rules> </nlog>
  •  將nlog.config設置輸出到目錄

  • 在Startup類中配置

需要引入命名空間:

using NLog.Extensions.Logging;

using NLog.Web;

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactor)
{
    //使用Nlog
    loggerFactor.AddNLog();
    //引入配置文件
    env.ConfigureNLog("nlog.config");
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
    }
    else
    {
        app.UseExceptionHandler("/Error");
    }
    app.UseStaticFiles();
    app.UseCookiePolicy();

    app.UseMvc();
}
  • 代碼中的使用

有兩中方式如下:

1、註入形式

public class IndexModel : PageModel
{
    private ILogger<IndexModel> _logger;
    public IndexModel(ILogger<IndexModel> logger)
    {
        _logger = logger;
    }
    public string Customer { get; set; }
    public void OnGet()
    {
        _logger.LogWarning("111111111111111111111");
        Customer = "123456";
    }
}

2、獲取實例形式

private static Logger Logger = LogManager.GetCurrentClassLogger();
public static void Main(string[] args)
{
    Logger.Error("22222222222222222222222222222");
    Logger.Info("333333333333333333333333333333");
}

 log4net

 log4net已支持net core,來看下在net core下是如何配置的,與之前的版本還是有一點的區別

  • 使用慣例,引用Nuget

log4net
  • 新建配置文件

<?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="logs/" /> 
      <appendToFile value="true" />
      <rollingStyle value="Date" />
      <staticLogFileName value="false" />
      <datePattern value="yyyy-MM-dd'.log'" />
      <maxSizeRollBackups value="7" />
      <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>

配置文件的相關說明,可以查看另一篇文章  點我跳轉

  • 在StartUp.cs中配置log4Net

public static ILoggerRepository repository { get; set; }
public Startup(IConfiguration configuration) { Configuration = configuration; //log4net repository = LogManager.CreateRepository("NETCoreRepository"); //指定配置文件 XmlConfigurator.Configure(repository, new FileInfo("log4net.config")); }

 

  •  Controller中的使用

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

[HttpGet]
public ActionResult<IEnumerable<string>> Get()
{
    log.Info(1111111111111111111);
    return new string[] { "value1", "value2" };
}

 

  • 控制臺中的使用

ILoggerRepository repository = LogManager.CreateRepository("NETCoreRepository");
XmlConfigurator.Configure(repository,
new FileInfo("log4net.config"));
ILog log
= LogManager.GetLogger(repository.Name,"NETCorelog4net"); log.Info("test log");

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 需要知識:python,Django框架,前端HTML,CSS,JS,JQuery,Bootstarp,Django的ORM,Auth 一.資料庫表的分析: 1.首先是用戶表,用戶表繼承Django自帶的Auth_user表,目的是可以使用Django封裝好的方法,不用自己手動寫cookie和ses ...
  • 文章大綱 一、Spring mvc介紹二、Spring mvc代碼實戰三、項目源碼下載四、參考文章 一、Spring mvc介紹 1. 什麼是springmvc springmvc是spring框架的一個模塊,springmvc和spring無需通過中間整合層進行整合。springmvc是一個基於m ...
  • 一:函數 二。函數的使用 三,函數的分類 四,函數的返回值 ...
  • 主要基於廖雪峰python教程的學習筆記, 內容:輸入輸出、基本數據類型、變數、除法、字元串 ...
  • 首先引入dll文件ICSharpCode.SharpZipLib.dll 管理NuGet包裡面下載 壓縮文件 文件下載 具體使用 ...
  • 最近做項目用到MVC,發現用linq查詢得到的數據是匿名類型對象,通過模型綁定、或者ViewBag、ViewData進行數據傳遞後,View解析報錯:“object 未包含xx的定義”; 沒找到好的解決辦法,就只能通過內部對象一個類型去解決。 所以想到了對內部對象一個類型轉換,轉換成Jobject, ...
  • 一、什麼是依賴註入 二、Asp.net core中依賴註入的生命周期 依賴註入的生命周期有三種Transient,Scoped和Singleton; 1、Transient每次調用都是不同的實例,比如常用的Microsoft.Extensions.Options.IConfigureOptions< ...
  • 本文介紹如何處理多個用戶併發更新同一實體(同時)時出現的衝突 。 主要是兩種:一種,檢查屬性併發衝突,使用 [ConcurrencyCheck] ;另一種,檢測行的併發衝突,使用 rowversion 跟蹤屬性,如果在保存之前有修改,就報錯 發生併發衝突的情況: 1.用戶導航到實體編輯頁面; 2.第 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...