Visual Studio版本:Microsoft Visual Studio Community 2015 Update 2
開發及運行平臺:Windows 7 專業版 Service Pack 1
在project.json文件中新增依賴項
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
{ "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)
我們這個控制臺程序主要目的是用來打印輸出日志,所以這里用一個單獨的日志配置文件來保存相關日志相關選項,比如:是否包括上下文,日志輸出最低等級等。
1
2
3
4
5
6
|
{ "IncludeScopes" : false , "LogLevel" : { "App" : "Warning" } } |
IncludeScopes為false讓控制臺日志輸出時不包含上下文;LogLevel的最低等級設置為:Warning,只有高于這個級別的日志才會輸出。App為日志的CategoryName。
入口程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
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以上的日志被輸出了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。