.NET Core創(chuàng)建一個控制臺(Console)程序
.NET Core版本:1.0.0-rc2
Visual Studio版本:Microsoft Visual Studio Community 2015 Update 2
開發(fā)及運行平臺:Windows 7 專業(yè)版 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)
我們這個控制臺程序主要目的是用來打印輸出日志,所以這里用一個單獨的日志配置文件來保存相關(guān)日志相關(guān)選項,比如:是否包括上下文,日志輸出最低等級等。
{
"IncludeScopes": false,
"LogLevel": {
"App": "Warning"
}
}
IncludeScopes為false讓控制臺日志輸出時不包含上下文;LogLevel的最低等級設(shè)置為: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();
// 創(chuàng)建ConsoleLogProvider并根據(jù)日志類目名稱(CategoryName)生成Logger實例
var logger = new ServiceCollection().AddLogging().BuildServiceProvider().GetService<ILoggerFactory>().AddConsole(setttins).CreateLogger("App");
// 設(shè)置事件ID
const int eventId = 888888;
// 輸出正常提示日志
logger.LogInformation(eventId, "訂單號({OderNo})", "12345678000");
// 輸出警示日志
logger.LogWarning(eventId, "待處理訂單數(shù)達到5分鐘內(nèi)的預(yù)警值:{max}", 2000);
// 輸出錯誤日志
logger.LogError(eventId, "數(shù)據(jù)庫連接超時");
Console.ReadLine();
}
}
}
使用“dotnet restore”來還原依賴項
在Git Bash中把當(dāng)前目錄切換到項目的根目錄下(本例為:D:\ConsoleLogApp)
dotnet restore命令是用來尋找當(dāng)前目錄下的項目文件(project.json),然后利用NuGet庫還原整個項目的依賴庫,然后遍歷每個目錄生成項目文件,繼續(xù)還原該項目文件中依賴項。

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

編譯成功后,我們在項目根目錄下的bin目錄中發(fā)現(xiàn)編譯后的文件夾(D:\ConsoleLogApp\bin\Debug\netcoreapp1.0),命令執(zhí)行成功后生成了一個Debug目錄并在此目錄下生成了一個以應(yīng)用名稱命名的文件夾(netcoreapp1.0,這個名稱是在project.json中配置的)
使用“dotnet run”來運行程序

我們可以看到info級別的輸出日志被過濾掉了,只有Warning以上的日志被輸出了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
WPF在自定義文本框中實現(xiàn)輸入法跟隨光標(biāo)
本文主要為大家介紹了如何在WPF寫一個自定義的文本框,并且能實現(xiàn)讓輸入法跟隨光標(biāo)。文中的示例代碼講解詳細(xì),需要的可以參考一下2022-02-02
通過Windows Visual Studio遠程調(diào)試WSL2中的.NET Core Linux應(yīng)用程序的方法
這篇文章主要介紹了通過Windows Visual Studio遠程調(diào)試WSL2中的.NET Core Linux應(yīng)用程序的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
asp.net中使用自定義控件的方式實現(xiàn)一個分頁控件的代碼
在web開發(fā)中,常常需要顯示一些數(shù)據(jù),而為了方便排版及瀏覽,我們只需要顯示所有記錄中的一部分。一般情況下,我們采用分頁來實現(xiàn)這個需求2012-10-10
.NET Core 實現(xiàn)定時抓取網(wǎng)站文章并發(fā)送到郵箱
本片文章通過實例講述.NET Core 實現(xiàn)定時抓取博客園首頁文章信息并發(fā)送到郵箱這個功能,對此有興趣的朋友參考學(xué)習(xí)下。2018-02-02
asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié)
asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié),需要的朋友可以參考下。2010-05-05
Silverlight融合ajax實現(xiàn)前后臺數(shù)據(jù)交互
兩年前Silverlight 還未起名,故事發(fā)生在WPF/E 的年代里。07年8月在中軟實習(xí)時,我承擔(dān)起了在. Net 中嵌入WPF/E 的任務(wù),目的是增強用戶體驗。2009-05-05
ASP.NET Core Controller與IOC結(jié)合問題整理
在本篇文章里小編給大家整理了一篇關(guān)于ASP.NET Core Controller與IOC結(jié)合問題整理內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2021-01-01

