溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在.NET Core中創(chuàng)建一個控制臺程序

發(fā)布時間:2020-07-09 14:13:38 來源:億速云 閱讀:160 作者:Leah 欄目:編程語言

這篇文章將為大家詳細講解有關如何在.NET Core中創(chuàng)建一個控制臺程序,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

.NET Core版本:1.0.0-rc2

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

開發(fā)及運行平臺:Windows 7 專業(yè)版 Service Pack 1

新增一個控制臺項目(ConsoleLogApp)

如何在.NET Core中創(chuàng)建一個控制臺程序

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();

      // 創(chuàng)建ConsoleLogProvider并根據(jù)日志類目名稱(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, "待處理訂單數(shù)達到5分鐘內(nèi)的預警值:{max}", 2000);

      // 輸出錯誤日志
      logger.LogError(eventId, "數(shù)據(jù)庫連接超時");

      Console.ReadLine();
    }
  }
}

使用“dotnet restore”來還原依賴項

在Git Bash中把當前目錄切換到項目的根目錄下(本例為:D:\ConsoleLogApp)

dotnet restore命令是用來尋找當前目錄下的項目文件(project.json),然后利用NuGet庫還原整個項目的依賴庫,然后遍歷每個目錄生成項目文件,繼續(xù)還原該項目文件中依賴項。

如何在.NET Core中創(chuàng)建一個控制臺程序

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

如何在.NET Core中創(chuàng)建一個控制臺程序

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

使用“dotnet run”來運行程序

如何在.NET Core中創(chuàng)建一個控制臺程序

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

關于如何在.NET Core中創(chuàng)建一個控制臺程序就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI