.NET Core創建一個控制台(Console)程序


.NET Core版本:1.0.0-rc2

Visual Studio版本:Microsoft Visual Studio Community 2015 Update 2

開發及運行平台:Windows 7 專業版 Service Pack 1

  • 新增一個控制台項目(ConsoleLogApp)

  • 在project.json文件中新增依賴項

{ "version": "1.0.0-*", "buildOptions": { "emitEntryPoint": true }, "dependencies": { "Microsoft.NETCore.App": { "type": "platform", "version": "1.0.0-rc2-3002702" }, "Microsoft.Extensions.DependencyInjection": "1.0.0-rc2-final", "Microsoft.Extensions.Logging": "1.0.0-rc2-final", "Microsoft.Extensions.Logging.Console": "1.0.0-rc2-final", "Microsoft.Extensions.Configuration.Json": "1.0.0-rc2-final", "System.Text.Encoding": "4.0.11-rc2-24027", "System.Text.Encoding.CodePages": "4.0.1-rc2-24027" }, "frameworks": { "netcoreapp1.0": { "imports": "dnxcore50" } } }
  • 新增日志輸出配置文件(log.json)

我們這個控制台程序主要目的是用來打印輸出日志,所以這里用一個單獨的日志配置文件來保存相關日志相關選項,比如:是否包括上下文,日志輸出最低等級等。

{ "IncludeScopes": false, "LogLevel": { "App": "Warning" } }

IncludeScopes為false讓控制台日志輸出時不包含上下文;LogLevel的最低等級設置為:Warning,只有高於這個級別的日志才會輸出。App為日志的CategoryName。

  • 入口程序

using System; using Microsoft.Extensions.Configuration; using System.Text; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; namespace ConsoleLogApp { public class Program { public static void Main(string[] args) { // 支持中文編碼
 Encoding.RegisterProvider(CodePagesEncodingProvider.Instance); // 加載日志配置文件
            var setttins = new ConfigurationBuilder().AddJsonFile("log.json").Build(); // 創建ConsoleLogProvider並根據日志類目名稱(CategoryName)生成Logger實例
            var logger = new ServiceCollection().AddLogging().BuildServiceProvider().GetService<ILoggerFactory>().AddConsole(setttins).CreateLogger("App"); // 設置事件ID
            const int eventId = 888888; // 輸出正常提示日志
            logger.LogInformation(eventId, "訂單號({OderNo})", "12345678000"); // 輸出警示日志
            logger.LogWarning(eventId, "待處理訂單數達到5分鍾內的預警值:{max}", 2000); // 輸出錯誤日志
            logger.LogError(eventId, "數據庫連接超時"); Console.ReadLine(); } } }
  • 使用“dotnet restore”來還原依賴項

    • 在Git Bash中把當前目錄切換到項目的根目錄下(本例為:D:\ConsoleLogApp)
    • dotnet restore命令是用來尋找當前目錄下的項目文件(project.json),然后利用NuGet庫還原整個項目的依賴庫,然后遍歷每個目錄生成項目文件,繼續還原該項目文件中依賴項。

 

 

  • 使用“dotnet build”來編譯整個項目

編譯成功后,我們在項目根目錄下的bin目錄中發現編譯后的文件夾(D:\ConsoleLogApp\bin\Debug\netcoreapp1.0),命令執行成功后生成了一個Debug目錄並在此目錄下生成了一個以應用名稱命名的文件夾(netcoreapp1.0,這個名稱是在project.json中配置的)

  • 使用“dotnet run”來運行程序

 我們可以看到info級別的輸出日志被過濾掉了,只有Warning以上的日志被輸出了。

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM