简介

.NET命令行接口 (CLI) 工具是用于开发、生成、运行和发布.NET应用程序的跨平台工具链。

温故知新,DotNet Core SDK和.Net CLI十八般武艺

https://docs.microsoft.com/zh-cn/dotnet/core/tools/

SDK

里程碑 发布日期
.NET Core 2.1.x (servicing) LTS (Long Term Support) release. Approximately every 1-2 months or as needed.
.NET Core 3.1.x (servicing) LTS (Long Term Support) release. Approximately every 1-2 months or as needed.
.NET 5.0 Release scheduled for November 2020
.NET 6.0 LTS (Long Term Support) release, scheduled for November 2021
.NET 7.0 Release scheduled for November 2022
.NET 8.0 LTS (Long Term Support) release, scheduled for November 2023

检查安装

dotnet

温故知新,DotNet Core SDK和.Net CLI十八般武艺

新建

dotnet new $templateName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

其中常见的模板名称有:

模板名字 短名称 版本要求
控制台应用程序 console >= 1.0
类库 classlib >= 1.0
WPF应用程序 wpf >= 3.0
WPF类库 wpflib >= 3.0
WPF自定义控件库 wpfcustomcontrollib >= 3.0
WPF用户控件库 wpfusercontrollib >= 3.0
Windows窗体(WinForms) 应用程序 winforms >= 3.0
Windows窗体(WinForms)类库 winformslib >= 3.0
Worker Service worker >= 3.0
单元测试项目 mstest >= 1.0
NUnit 3测试项目 nunit >= 2.1
NUnit 3测试项 nunit-test >= 2.2
xUnit 测试项目 xunit >= 1.0
Razor组件 razorcomponent >= 3.0
Razor页 page >= 2.0
MVC ViewImports viewimports >= 2.0
MVC ViewStart viewstart >= 2.0
Blazor 服务器应用 blazorserver >= 3.0
Blazor WebAssembly应用 blazorwasm >= 3.1
ASP.NET Core空 web >= 1.0
ASP.NET Core Web应用程序 (Model-View-Controller) mvc >= 1.0
ASP.NET Core Web 应用程序 webapp, razor >= 2.0
含 Angular 的ASP.NET Core angular >= 2.0
含 React.js 的ASP.NET Core react >= 2.0
含 React.js 和 Redux 的ASP.NET Core reactredux >= 2.0
Razor类库 razorclasslib >= 2.1
ASP.NET Core Web API webapi >= 1.0
ASP.NET Core gRPC服务 grpc >= 3.0
dotnet gitignore文件 gitignore >= 3.0
global.json文件 globaljson >= 2.0
NuGet配置 nugetconfig >= 1.0
Dotnet本地工具清单文件 tool-manifest >= 3.0
Web配置 webconfig >= 1.0
解决方案文件 sln >= 1.0
协议缓冲区文件 proto >= 3.0

可选参数--list可查看本地安装的所有模板

dotnet new --list

温故知新,DotNet Core SDK和.Net CLI十八般武艺

可选参数-f 指定目标框架版本号

dotnet new $templateName -f $frameworkName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

  • net5.0
  • netcoreapp3.1
  • netcoreapp3.0
  • netcoreapp2.1
dotnet new webapi -f netcoreapp2.1

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

dotnet new webapi -f netcoreapp3.1

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

dotnet new webapi -f netcoreapp2.2

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

dotnet new webapi -f net5.0

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

可选参数-n 指定创建的输出名称,否认默认是当前文件夹名称

dotnet new webapi -n $projectName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

https://docs.microsoft.com/zh-cn/dotnet/core/tools/dotnet-new

可选参数-o 指定输出目录,默认是当前目录

dotnet new webapi -o $projectName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

可选参数--no-https关闭默认HTTPS要求,方便开发调试

dotnet new webapi -o $projectName --no-https

温故知新,DotNet Core SDK和.Net CLI十八般武艺

新建一个解决方案。

dotnet new sln -o $solutionName

给解决方案添加项目

dotnet sln add $projectName.csproj

从解决方案中移除项目

dotnet sln remove $projectName.csproj

自定义模板

https://docs.microsoft.com/zh-cn/dotnet/core/tools/custom-templates

安装新模板

dotnet new -i $package_nuget_id

这里的-i代表了install安装的意思

比如:

dotnet new -i Stylet.Templates

温故知新,DotNet Core SDK和.Net CLI十八般武艺

还可以从本地Nuget包来进行安装

dotnet new -i $package_nuget_file_path

这里$package_nuget_file_path,提供指向.nupkg NuGet包文件的路径。

查看已安装模板

dotnet new --list

温故知新,DotNet Core SDK和.Net CLI十八般武艺

卸载指定模板

dotnet new -u $package_nuget_id

这里的-u代表了uninstall卸载的意思

比如:

dotnet new -u Stylet.Templates

温故知新,DotNet Core SDK和.Net CLI十八般武艺

还原依赖

dotnet restore
dotnet restore $target.csproj

温故知新,DotNet Core SDK和.Net CLI十八般武艺

运行

dotnet run

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

输出文件会写入到默认位置,即bin/<configuration>/<target>。 例如,如果具有netcoreapp2.1应用程序并且运行dotnet run,则输出置于bin/Debug/netcoreapp2.1。 将根据需要覆盖文件。临时文件将置于obj目录。

如果在上下文中,需要直接运行某个文件,可以用

dotnet $fileName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

禁止隐式还原

dotnet run --no-restore

温故知新,DotNet Core SDK和.Net CLI十八般武艺

禁止生成项目

dotnet run --no-build

温故知新,DotNet Core SDK和.Net CLI十八般武艺

生成

dotnet build

温故知新,DotNet Core SDK和.Net CLI十八般武艺

dotnet build命令将项目及其依赖项生成为一组二进制文件。 二进制文件包括扩展名为.dll的中间语言 (IL) 文件中的项目代码。

根据项目类型和设置,可能会包含其他文件,例如:

  • 可用于运行应用程序的可执行文件(如果项目类型是面向.NET Core 3.0或更高版本的可执行文件)。
  • 用于调试的扩展名为.pdb的符号文件。
  • 列出了应用程序或库的依赖项的.deps.json文件。
  • 用于指定应用程序的共享运行时及其版本的.runtimeconfig.json文件。
  • 项目通过项目引用或 NuGet 包引用所依赖的其他库。

对于目标版本低于.NET Core 3.0的可执行项目,通常不会将NuGet中的库依赖项复制到输出文件夹。 而是在运行时从NuGet全局包文件夹中对其进行解析。

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

对于面向.NET Core 3.0及更高版本的可执行项目,库依赖项会被复制到输出文件夹。 这意味着如果没有其他任何特定于发布的逻辑(例如,Web项目具有的逻辑),则应可部署生成输出。

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

输出可执行文件还是输出库的配置

要生成库,请省略<OutputType>属性或将其值更改为Library

<PropertyGroup>
  <OutputType>Exe</OutputType>
</PropertyGroup>

温故知新,DotNet Core SDK和.Net CLI十八般武艺

<PropertyGroup>
  <OutputType>Library</OutputType>
</PropertyGroup>

温故知新,DotNet Core SDK和.Net CLI十八般武艺

指定生成模式

  • Debug
  • Release
dotnet build -c Release

温故知新,DotNet Core SDK和.Net CLI十八般武艺

dotnet build -c Debug

温故知新,DotNet Core SDK和.Net CLI十八般武艺

指定文件版本

dotnet build -p:Version=$targetVersion

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

清理

dotnet clean
dotnet clean -c Release

温故知新,DotNet Core SDK和.Net CLI十八般武艺

打包

dotnet pack
dotnet pack -c Release

温故知新,DotNet Core SDK和.Net CLI十八般武艺

默认情况下,Web 项目不可打包。 若要覆盖默认行为,请将以下属性添加到 .csproj 文件中

<PropertyGroup>
   <IsPackable>true</IsPackable>
</PropertyGroup>

Nuget

添加源

dotnet nuget add source $nugetUrl -n $sourceName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

列举源

dotnet nuget list source

温故知新,DotNet Core SDK和.Net CLI十八般武艺

删除源

dotnet nuget remove source $sourceName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

推送包到指定源

dotnet nuget push $packageName.nupkg -k $sourceAuthKey -s $sourceUrl

温故知新,DotNet Core SDK和.Net CLI十八般武艺

删除包

dotnet nuget delete $packageName $packageVersion -s $sourceName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

发布

dotnet publish

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

dll文件的形式将应用发布为依赖于框架的应用时,将创建跨平台二进制文件。 dll文件将与项目同名。 例如,如果有名为demoForWebApp3.1的应用,则会创建名为demoForWebApp3.1.dll的文件。 以这种方式发布的应用可通过dotnet <filename.dll>命令运行,并且可在任意平台上运行。

只要安装了目标.NET 运行时,就可以在任何操作系统上运行跨平台二进制文件。 如果未安装目标.NET运行时,如果将应用配置为前滚,则它可以使用较新的运行时运行。

指定框架的发布

--runtime => -r

dotnet publish -r linux-x64 --self-contained false
dotnet publish -r win-x64 --self-contained false

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

所有可选的框架清单:https://docs.microsoft.com/zh-cn/dotnet/core/rid-catalog

其中--self-contained false参数表示不包括对应框架运行时。

dotnet publish -r linux-x64
dotnet publish -r win-x64

将包含完整的目标框架运行时+程序

将应用发布为独立应用,将生成特定于平台的可执行文件。 输出发布文件夹包含应用的所有组件,包括.NET库和目标运行时。 应用独立于其他.NET应用,且不使用本地安装的共享运行时。 应用的用户无需下载和安装.NET。

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

直接生成ReadyToRun映像

dotnet publish -c Release -r win-x64 -p:PublishReadyToRun=true

温故知新,DotNet Core SDK和.Net CLI十八般武艺

使用ReadyToRun映像发布可以缩短应用程序的启动时间,但代价是增加应用程序的大小。

https://docs.microsoft.com/zh-cn/dotnet/core/deploying/#produce-a-cross-platform-binary

指定项目文件发布

dotnet publish $packageName.csproj

温故知新,DotNet Core SDK和.Net CLI十八般武艺

监听并自动生成

开发阶段在源文件发生变动的情况下就自动执行dotnet build

dotnet watch run

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

包管理

添加包

dotnet add package $packageName
dotnet add package $packageName -v $packageVersion

温故知新,DotNet Core SDK和.Net CLI十八般武艺

查看已安装包

dotnet list package

温故知新,DotNet Core SDK和.Net CLI十八般武艺

移除某安装包

dotnet remove package $packageName

温故知新,DotNet Core SDK和.Net CLI十八般武艺

用VSC打开当前目录

先cd到需要打开的当前目录,然后输入命令:

code .

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

让VSC支持C#语法检查

只要安装C#插件即可。

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

让VSC支持自动Using

只要安装Auto-Using for C#这个插件即可。

温故知新,DotNet Core SDK和.Net CLI十八般武艺

温故知新,DotNet Core SDK和.Net CLI十八般武艺

相关文章:

  • 2021-07-08
  • 2021-10-31
  • 2021-08-24
  • 2021-12-09
  • 2022-01-14
  • 2021-08-01
  • 2021-08-07
猜你喜欢
  • 2022-12-23
  • 2022-02-08
  • 2021-09-19
  • 2022-02-22
  • 2021-10-13
  • 2022-01-27
相关资源
相似解决方案