当前位置: 移动技术网 > IT编程>开发语言>.net > .NET Core创建一个控制台(Console)程序

.NET Core创建一个控制台(Console)程序

2017年12月08日  | 移动技术网IT编程  | 我要评论

.net core版本:1.0.0-rc2

visual studio版本:microsoft visual studio community 2015 update 2

开发及运行平台:windows 7 专业版 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)

我们这个控制台程序主要目的是用来打印输出日志,所以这里用一个单独的日志配置文件来保存相关日志相关选项,比如:是否包括上下文,日志输出最低等级等。

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

      // 创建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以上的日志被输出了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网