.NET Core創(chuàng)建一個(gè)控制臺(tái)(Console)程序
.NET Core版本:1.0.0-rc2
Visual Studio版本:Microsoft Visual Studio Community 2015 Update 2
開(kāi)發(fā)及運(yùn)行平臺(tái):Windows 7 專(zhuān)業(yè)版 Service Pack 1
新增一個(gè)控制臺(tái)項(xiàng)目(ConsoleLogApp)
在project.json文件中新增依賴(lài)項(xiàng)
{ "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)
我們這個(gè)控制臺(tái)程序主要目的是用來(lái)打印輸出日志,所以這里用一個(gè)單獨(dú)的日志配置文件來(lái)保存相關(guān)日志相關(guān)選項(xiàng),比如:是否包括上下文,日志輸出最低等級(jí)等。
{ "IncludeScopes": false, "LogLevel": { "App": "Warning" } }
IncludeScopes為false讓控制臺(tái)日志輸出時(shí)不包含上下文;LogLevel的最低等級(jí)設(shè)置為:Warning,只有高于這個(gè)級(jí)別的日志才會(huì)輸出。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ù)日志類(lèi)目名稱(chēng)(CategoryName)生成Logger實(shí)例 var logger = new ServiceCollection().AddLogging().BuildServiceProvider().GetService<ILoggerFactory>().AddConsole(setttins).CreateLogger("App"); // 設(shè)置事件ID const int eventId = 888888; // 輸出正常提示日志 logger.LogInformation(eventId, "訂單號(hào)({OderNo})", "12345678000"); // 輸出警示日志 logger.LogWarning(eventId, "待處理訂單數(shù)達(dá)到5分鐘內(nèi)的預(yù)警值:{max}", 2000); // 輸出錯(cuò)誤日志 logger.LogError(eventId, "數(shù)據(jù)庫(kù)連接超時(shí)"); Console.ReadLine(); } } }
使用“dotnet restore”來(lái)還原依賴(lài)項(xiàng)
在Git Bash中把當(dāng)前目錄切換到項(xiàng)目的根目錄下(本例為:D:\ConsoleLogApp)
dotnet restore命令是用來(lái)尋找當(dāng)前目錄下的項(xiàng)目文件(project.json),然后利用NuGet庫(kù)還原整個(gè)項(xiàng)目的依賴(lài)庫(kù),然后遍歷每個(gè)目錄生成項(xiàng)目文件,繼續(xù)還原該項(xiàng)目文件中依賴(lài)項(xiàng)。
使用“dotnet build”來(lái)編譯整個(gè)項(xiàng)目
編譯成功后,我們?cè)陧?xiàng)目根目錄下的bin目錄中發(fā)現(xiàn)編譯后的文件夾(D:\ConsoleLogApp\bin\Debug\netcoreapp1.0),命令執(zhí)行成功后生成了一個(gè)Debug目錄并在此目錄下生成了一個(gè)以應(yīng)用名稱(chēng)命名的文件夾(netcoreapp1.0,這個(gè)名稱(chēng)是在project.json中配置的)
使用“dotnet run”來(lái)運(yùn)行程序
我們可以看到info級(jí)別的輸出日志被過(guò)濾掉了,只有Warning以上的日志被輸出了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
WPF在自定義文本框中實(shí)現(xiàn)輸入法跟隨光標(biāo)
本文主要為大家介紹了如何在WPF寫(xiě)一個(gè)自定義的文本框,并且能實(shí)現(xiàn)讓輸入法跟隨光標(biāo)。文中的示例代碼講解詳細(xì),需要的可以參考一下2022-02-02通過(guò)Windows Visual Studio遠(yuǎn)程調(diào)試WSL2中的.NET Core Linux應(yīng)用程序的方法
這篇文章主要介紹了通過(guò)Windows Visual Studio遠(yuǎn)程調(diào)試WSL2中的.NET Core Linux應(yīng)用程序的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07asp.net中使用自定義控件的方式實(shí)現(xiàn)一個(gè)分頁(yè)控件的代碼
在web開(kāi)發(fā)中,常常需要顯示一些數(shù)據(jù),而為了方便排版及瀏覽,我們只需要顯示所有記錄中的一部分。一般情況下,我們采用分頁(yè)來(lái)實(shí)現(xiàn)這個(gè)需求2012-10-10.NET Core 實(shí)現(xiàn)定時(shí)抓取網(wǎng)站文章并發(fā)送到郵箱
本片文章通過(guò)實(shí)例講述.NET Core 實(shí)現(xiàn)定時(shí)抓取博客園首頁(yè)文章信息并發(fā)送到郵箱這個(gè)功能,對(duì)此有興趣的朋友參考學(xué)習(xí)下。2018-02-02.Net實(shí)現(xiàn)上傳圖片按比例自動(dòng)縮小或放大的方法
這篇文章主要介紹了.Net實(shí)現(xiàn)上傳圖片按比例自動(dòng)縮小或放大的方法,實(shí)例內(nèi)容簡(jiǎn)潔功能實(shí)用,需要的朋友可以參考下2014-09-09asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié)
asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié),需要的朋友可以參考下。2010-05-05Silverlight融合ajax實(shí)現(xiàn)前后臺(tái)數(shù)據(jù)交互
兩年前Silverlight 還未起名,故事發(fā)生在WPF/E 的年代里。07年8月在中軟實(shí)習(xí)時(shí),我承擔(dān)起了在. Net 中嵌入WPF/E 的任務(wù),目的是增強(qiáng)用戶體驗(yàn)。2009-05-05asp.net 相關(guān)文章實(shí)現(xiàn)方法
大家或許會(huì)覺(jué)得很驚訝:為什么靈感之源會(huì)討論SQL?或許應(yīng)該這樣說(shuō)吧:搞業(yè)務(wù)系統(tǒng),不跟SQL扯上關(guān)系似乎比較難。2009-05-05Asp.net 時(shí)間操作基類(lèi)(支持短日期,長(zhǎng)日期,時(shí)間差)
支持短日期,長(zhǎng)日期,時(shí)間差的操作基類(lèi),方便大家直接使用2008-11-11ASP.NET Core Controller與IOC結(jié)合問(wèn)題整理
在本篇文章里小編給大家整理了一篇關(guān)于ASP.NET Core Controller與IOC結(jié)合問(wèn)題整理內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2021-01-01