欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.NET Core創(chuàng)建一個(gè)控制臺(tái)(Console)程序

 更新時(shí)間:2017年04月10日 09:27:18   作者:FrankYou  
這篇文章主要為大家詳細(xì)介紹了.NET Core如何創(chuàng)建一個(gè)控制臺(tái)程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

.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)文章

最新評(píng)論