如何编写.NET Core Global Tools (附两个案例)
一.什么是 .NET Core Global Tools
2018年5月31日(北京时间)微软发布了 .NET Core 2.1 正式版,.NET Core 2.1 为我们带来了一个新的特性:.NET Core Global Tools。用过NodeJs的人一定对NPM不会陌生,它就是受到NPM的启发,为提供了.NET Core tools 提供了一个新的部署和扩展机制 。它是一个 .NET Core 控制台应用程序,它们是作为 NuGet 包来打包和获取的。默认情况下,这些 tools 是依赖于框架的应用程序 ,并包含其所有的 NuGet 依赖项。这意味着 .NET Core tools 默认运行在所有支持 .NET Core 的操作系统和芯片架构上,并带有一组二进制文件。默认情况下,dotnet tool install 命令会在 NuGet.org 上查找 tools 。您也可以改用您自己的 NuGet 源。
二.使用
请确保你的.NET Core SDK升级到2.1(版本号2.1.300),若没有请访问官网进行安装:https://www.microsoft.com/net/learn/get-started/windows
我们主要使用 dotnet tool 命令来进行操作:
使用情况: dotnet tool [选项] [命令]
选项:
-h, --help 显示帮助信息。
命令:
install <PACKAGE_ID> 安装在命令行上使用的工具。
uninstall <PACKAGE_ID> 卸载工具。
update <PACKAGE_ID> 将工具更新为最新稳定版本以供使用。
list 列出当前开发环境中的已安装工具。
1.命令使用:
(1).安装tool dotnet tool install -g <工具ID>
(2).卸载tool dotnet tool uninstall -g <工具ID>
(3).更新tool dotnet tool update -g <工具ID>
(4).列出本地已安装tool dotnet tool list -g
2.安装第一个tool
官方为我们提供了一个tool示例 dotnetsay,我们通过命令进行安装:
dotnet tool install -g dotnetsay

然后我们执行命令使用该工具
dotnetsay
它为我我们输出了一个机器人:

你可以访问 dotnetsay 的源码来学习如何编写 tool。
三.编写第一个.NET Core Global Tool
1.新建一个.NET Core 控制台程序

2.编写代码
我们编写一句代码,输出 “Hello .NET Core Global Tools”。
using System;
namespace HelloDotnetCoreTool
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Hello .NET Core Global Tools");
}
}
}
3.编辑csproj文件
选中项目->右键菜单->编辑csproj文件,在 PropertyGroup节点下加入:
<PackAsTool>true</PackAsTool>
完整示例:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<PackAsTool>true</PackAsTool>
<TargetFramework>netcoreapp2.1</TargetFramework>
</PropertyGroup>
</Project>
4.编辑Nuget包信息
选中项目->右键菜单->属性->Package,编辑我们的包信息。

5.打包
我们可以使用 dotnet pack 命令来进行打包,也可以使用VS提供的菜单来进行打包:选中项目->右键菜单->打包 (项目配置选为 Release),然后在 bin\Release目录下,就可以找到我们打包的nuget包。

6.安装
打开命令提示符(cmd),进入到nuget包所在目录,执行命令进行安装:
dotnet tool install -g HelloDotnetCoreTool --add-source ./
出现如下提示表示安装成功:

然后我们使用list命令来进行查询已安装的工具列表:
dotnet tool list -g

可以看到,我们编写的工具已经安装成功了。
7.使用
我们在命令提示符(cmd)中使用命令 hellodotnetcoretool,可以输出我们刚刚编写的 “Hello .NET Core Global Tools”

四.发布到 nuget.org
我们可以将我们编写的工具发布到 nuget.org ,那么任何人都可以通过命令安装、使用我们的工具了。
使用浏览器访问:http://www.nuget.org/ ,然后注册账户进行登录。
我们选择右上角的菜单 “Upload Packages”
选择我们刚刚打包的文件进行上传就可以了:

上传以后,需要等待10分钟左右,nuget.org 会对你的包来进行验证,这个时候你是无法通过命令来安装你的工具的,只有验证通过了才行。然后再等20分钟左右,nuget.org 便会对你的工具进行索引,这个时候就能过通过搜索来访问你的工具了。
五.案例
我编写了两个实用的 .NET Core Global Tool ,在这里为大家做一下简单的介绍
1.DotnetRSA
它是一个生成RSA加密算法所需的秘钥的工具,支持生成xml、pkcs1、pkcs8三种格式,并且支持三种格式之间进行相互转换。它是一个正规的命令行应用程序。你可以使用命令来进行安装:
dotnet tool install -g dotnetrsa
详细介绍:https://www.cnblogs.com/stulzq/p/9131074.html
项目地址:https://github.com/stulzq/dotnetrsa
简单演示,生成一个 xml 格式,长度为2048的RSA秘钥
dotnetrsa gen -f xml -s 2048 -o d:\

生成的秘钥:


2.dotnet-cnblog
前面我写了一篇文章 《如何高效的编写与同步博客 (.NET Core 小工具实现)》,在里面我介绍了一个使用 .NET Core 实现的可以快速解析Markdown文件里的本地图片,并上传到博客园,同事进行内容转换然后保存到新的文件里,可以让你的博客快速的发布在博客园,不需要手动对每张图片进行上传,是一个十分方便快捷使用的小工具,现在我将它改造成了 .NET Core Global Tool,你可以使用命令来进行安装:
dotnet tool install -g dotnet-cnblog
使用方法为:
dotnet-cnblog <Markdown文件路径>
使用演示:

详细介绍以及项目地址请访问:https://github.com/stulzq/CnBlogPublishTool
六.其他工具
由 natemcmaster 维护了一个工具列表,请访问 https://github.com/natemcmaster/dotnet-tools 进行查看,我编写的dotnetrsa工具已加入此列表。

七.参考资料
- [翻译] .NET Core 2.1 发布
- .NET Core 2.1 Global Tools
- 本文所用代码:https://github.com/stulzq/BlogDemos/tree/master/HelloDotnetCoreTool
如何编写.NET Core Global Tools (附两个案例)的更多相关文章
- [尝鲜]妈妈再也不用担心 dotnet core 程序发布了: .NET Core Global Tools
什么是 .NET Core Global Tools? Global Tools是.NET Core 2.1 中一个初次出现的特性.Global Tools提供了一种方法,让开发人员编写的.NET C ...
- 如何创建一个自己的.NET Core Global Tools
索引 NET Core应用框架之BitAdminCore框架应用篇系列 框架演示:https://www.bitadmincore.com 框架源码:https://github.com/chenyi ...
- NET Core 2.1 Global Tools
微软工程师Nate McMaster的博文.NET Core 2.1 Global Tools https://natemcmaster.com/blog/2018/05/12/dotnet-glob ...
- .NET Core开发日志——Global Tools
.NET Core 2.1引入了一个新的功能,Global Tools,其本质是包含控制台应用程序的nuget包,目前而言,还没有特别有用的工具,不过相信随着时间的推移,各种有创意或者实用性强的Glo ...
- RHEL / CentOS Linux Install Core Development Tools Automake, Gcc (C/C++), Perl, Python & Debuggers
how do I install all developer tools such as GNU GCC C/C++ compilers, make and others, after install ...
- python练习:编写一个函数isIn,接受两个字符串作为参数,如果一个字符串是另一个字符串的一部分,返回True,否则返回False。
python练习:编写一个函数isIn,接受两个字符串作为参数,如果一个字符串是另一个字符串的一部分,返回True,否则返回False. 重难点:定义函数的方法.使用str类型的find()函数,可以 ...
- 使用 VSCode 编写 .NET Core 项目之初体验
注:本文在根据 微软官方文档指导下,根据自己的学习中整理,并不完全照搬文档,但也大体和文档学习路线相似,主要为记录学习过程. 官方学习地址: https://code.visualstudio.com ...
- .Net Core WebApi上传图片的两种方式
我这边主要是为了上传图片,话不多说,上代码. 方式一:通过Form表单上传 后端: /// <summary> /// 上传图片,通过Form表单提交 /// </summary&g ...
- 如何在vscode中编写.net core 项目(vscode)
1.下载拓展 .NET Core Extension Pack (作者:保哥) 这个里面将需要的插件都打包了小白一键下载就好了 2.下载扩展 vscode-solution-explorer ...
随机推荐
- Android开发学习之RecyclerView
1.在app/build.gradle中添加RecyclerView依赖 implementation 'com.android.support:recyclerview-v7:28.0.0' 注意依 ...
- 确认是否是因为做了物理I/O而导致的性能不佳
要获取语句是否进行了I/O,需要打开set statistics on 和set statistics on.
- 如何解决远程连接mysql出现Can’t connect to MySQL server on (111 “Connection refused”)的问题
如何解决远程连接mysql出现Can’t connect to MySQL server on (111 “Connection refused”)的问题 开放Mysql的远程连接 在服务器上登录my ...
- mysql中导入导出sql文件
1.导出整个数据库: mysqldump -u用户名 -p密码 数据库名 > 导出的文件名 例:mysqldump -uroot -proot user > user.sql 2.导出一个 ...
- RHEL/Centos7 安装图形化桌面
Linux是一个多任务的多用户的操作系统,好多linux爱好者在安装完linux后经常遇到一个问题——没有图形化桌面.今天小编在安装RHEL7的时候,一步留神没有安装图形化桌面,下面分享一下安装图形化 ...
- C++多线程同步技巧(一) --- 临界区
简介 C++中关于多线程的内容对于构建工程来说是至关重要的,C++本身也对关于多线程的操作提供了很好的支持.本章笔者就来介绍一下C++有关于多线程的重要知识点---临界区. 临界区的作用 线程就像是进 ...
- 对Can We MakeOperating SystemsReliable and Secure 的翻译
摘要:微内核-相对于大内核(monolithic kernels)来说,由于它的 lower performance,长期以来被认为是不可接受的.而现在,由于它潜 在的高可靠性(higher reli ...
- puppet 和 apache passenger的配置
目录 1. 概要 2. apache passenger 安装测试 2.1. 什么是 apache passenger 2.2. 安装 apache passenger 2.3. 配置 apache ...
- JSX格式化代码,你值得拥有!
ext install prettier-vscode https://segmentfault.com/q/1010000014822745
- 5255 -- 【FJOI2016】神秘数
5255 -- [FJOI2016]神秘数 Description 一个可重复数字集合\(S\) 的神秘数定义为最小的不能被 \(S\) 的子集的和表示的正整数.例如: \(S = {1,1,1,4, ...