C# 使用/配置Log4Net

来源:https://www.cnblogs.com/Liyuting/archive/2018/02/05/8417757.html
-Advertisement-
Play Games

1、首先在項目中添加Nuget程式包... 2、然後在NuGet窗體中搜索Log4Net,然後點擊安裝<安裝過程可能會持續幾分鐘,請耐心等待> 3、在項目中添加一個Config文件,如已有App.config,則直接在其中添加內容: 截圖中配置的XML代碼如下: 最後在項目的 AssemblyInf ...


1、首先在項目中添加Nuget程式包...

2、然後在NuGet窗體中搜索Log4Net,然後點擊安裝<安裝過程可能會持續幾分鐘,請耐心等待>

3、在項目中添加一個Config文件,如已有App.config,則直接在其中添加內容:

截圖中配置的XML代碼如下:

 

  <log4net>
    <logger name="logerror">
      <level value="ERROR" />
      <appender-ref ref="ErrorAppender" />
    </logger>
    <logger name="loginfo">
      <level value="INFO" />
      <appender-ref ref="InfoAppender" />
    </logger>
    <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogError\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="MaxFileSize" value="10240" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n異常時間:%d %n異常級別:%-5p%n異常內容:%m%n" />
      </layout>      <!--&lt; &gt; = <> %n = 回車-->
    </appender>
    <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogInfo\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxFileSize" value="10240" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="日誌時間:%d %n日誌級別:%-5p  %n日誌內容:%m%n%n" />
      </layout>
    </appender>
  </log4net>

 

最後在項目的 AssemblyInfo.cs 文件中註冊Config文件,如下:

 

//為項目註冊Log4Net.config配置文件
[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)]

最後,添加日誌類:

 

    public class LogHelper
    {
        private LogHelper()
        {

        }

        public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");

        public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");

        public static void SetConfig()
        {
            log4net.Config.XmlConfigurator.Configure();
        }

        public static void SetConfig(FileInfo configFile)
        {
            log4net.Config.XmlConfigurator.Configure(configFile);
        }

        public static void WriteLog(string info)
        {
            if (loginfo.IsInfoEnabled)
            {
                loginfo.Info(info);
            }
        }

        public static void WriteLog(string info, Exception se)
        {
            if (logerror.IsErrorEnabled)
            {
                logerror.Error(info, se);
            }
        }
    }

 

好了,到了這裡,準備工作也就完成了,下麵我們就開始測試下吧

 

 日誌文件預設記錄在根目錄下,在config中可以更改路徑

 


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

-Advertisement-
Play Games
更多相關文章
  • 什麼是JSP內置對象 JSP引擎在調用JSP對應的jspServlet時, 會傳遞或創建9個與web開發相關的對象供jspServlet使用 。JSP技術的設計者為便於開發人員在編寫JSP頁面時獲得這些web對象的引用,特意定義了9個相應的變數, 開發人員在JSP頁面中通過這些變數就可以快速獲得這9 ...
  • 調試socket通信的時候,如果程式未正常結束,重新啟動會報埠被占用的錯誤。 一 查找被占用的埠 解決辦法如下:按win+R輸入cmd打開控制台,輸入 查看8080埠被哪個進程所占用,結果如下: 改圖顯示8080被進程id為5036的程式所占用。 二、通過任務管理器殺死相關的進程 方法一:使用 ...
  • ServiceStack是一個NET環境下的開源框架集合 包括輕量級的Orm框架,資料庫訪問,Json處理,Redis驅動等多個模塊,我們可以按需選擇使用 serviceStack.Ormlite serviceStack.Ormlite是一個.NET平臺快速實現ORM的數據訪問框架,支持多種主流的 ...
  • 轉載自:http://blog.csdn.net/baple/article/details/8131717 用ADOX創建ACCESS數據文件後,*.ldb文件出現,直到程式關閉後才消失。怎樣可以使那個*.ldb文件不出來呢?(具體它出來會有什麼壞處?我也沒細想,反正就是不想它出現。) Inter ...
  • 由於自己喜歡看小說,有的時候不方便手機看的時候希望在電腦上面看,但很多網站有廣告啊,於是封裝了套手機版的追書神器API 目前只做了搜索 詳情 書評 換源 正文 調用方式: 鏈接: https://pan.baidu.com/s/1pMNgMqZ 密碼: kpy6 ...
  • ASP.NET MVC框架提供了數據驗證的API,稱為"模型數據註解"或“模型元數據”,使我們可以使用聲明語法在模型中指定驗證的規則,常見的驗證API如下: 數據驗證API位於using System.ComponentModel.DataAnnotations;命名空間。 Movie.cs Ind ...
  • 通過製作一個登錄小案例來搭建MVC簡單三層 在View --Shared下創建一個母版頁: <!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width" /> <script src="~/Scrip ...
  • MVC自帶一個異常過濾器即 HandleErrorAttribute 1.首先要進行配置web.config defaultRedirect表示需要跳轉的錯誤頁面,mode需設置為 on或者 RemoteOnly. 註:HandleError只處理伺服器500錯誤,404、400等這些錯誤不進行處理 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...