商城首页欢迎来到中国正版软件门户

您的位置:首页 >c#如何使用NuGet包管理器_c#NuGet包管理器的几种常见写法

c#如何使用NuGet包管理器_c#NuGet包管理器的几种常见写法

  发布于2026-05-02 阅读(0)

扫一扫,手机访问

Visual Studio 中 NuGet Package Manager 窗口在 SDK 风格项目中默认隐藏,推荐使用右键“Manage NuGet Packages”或编辑 .csproj;Package Manager Console 需手动启用,且需正确配置源、项目上下文和目标框架兼容性。

c#如何使用NuGet包管理器_c#NuGet包管理器的几种常见写法

Visual Studio 里点不亮 NuGet Package Manager 窗口?

这事儿挺常见,但原因可能和你想的不太一样。问题往往不在于你的 Visual Studio 坏了,而在于项目类型本身。对于现代的 .NET Core 或 .NET 5 以上的 SDK 风格项目(也就是项目文件里写着 Sdk="Microsoft.NET.Sdk" 的那种),新版本的 VS 已经默认隐藏了那个经典的“NuGet Package Manager”窗口。

为什么?因为微软更推荐你使用两种新方式:要么右键点击项目,选择 Manage NuGet Packages... 那个图形界面;要么更直接一点,打开 .csproj 文件手动编辑。如果你在右键菜单里压根没找到这个选项,先别急。检查一下你的项目文件,看看里面是不是已经包含了 节点。如果项目还在使用老旧的 packages.config 文件,那说明它还没迁移到新的包管理格式,这时候那个旧的“NuGet Package Manager”窗口倒是有可能出现——不过,这已经是过时的做法了。

  • 在 VS 2022 里,Tools → NuGet Package Manager → Package Manager Console 这个控制台默认是禁用自动加载的。第一次想用它?得手动去 Tools → Options → Environment → Startup 里,勾选上 Load last loaded package manager console 才行。
  • 控制台打开后,默认的操作上下文是 Default Project。如果下拉框里空空如也,或者执行命令时总报 Unable to find package 这类错,第一步先确认在下拉框里选中了具体的项目(注意,是项目,不是整个解决方案)。
  • 另外,这个 Package Manager Console 本质上是个 PowerShell 环境,但它被 NuGet 模块“接管”了。这意味着你不能在里面随意运行所有 PowerShell 命令(比如你敲个 ls 试试,很可能就会报错)。

Install-Package 命令为什么总提示找不到包?

命令敲下去,结果蹦出来一个“找不到包”?先别怀疑自己拼错了包名——虽然这也可能——但更常见的原因是“源”没配对。Visual Studio 默认通常只启用了官方的 nuget.org 源。如果你需要从公司内部的私有源、GitHub Packages 或者 Azure Artifacts 拉取包,这些源都需要手动添加进去。

怎么查看当前有哪些源?在 Package Manager Console 里执行 Get-PackageSource 命令一目了然。要添加新源,可以用类似这样的命令:Register-PackageSource -Name "MyFeed" -Location "https://api.nuget.org/v3/index.json" -ProviderName "NuGet"。关键点在于,那个 -ProviderName 参数必须指定为 NuGet

  • 包名是区分大小写的。Newtonsoft.Json 就是 Newtonsoft.Json,写成全小写的 newtonsoft.json 可能在某些场景下能被自动纠正,但别指望每次都这么幸运。
  • 想安装特定版本?记得加上 -Version 参数,比如 Install-Package Microsoft.Extensions.Logging -Version 7.0.0。如果不加,默认安装的就是最新的稳定版(预发布版本会被跳过)。
  • 还有一种“静默失败”的情况:你的项目目标是 .NET Framework 4.6.1,却试图安装一个只支持 .NET 6 及以上版本的包(例如某些 Microsoft.AspNetCore.Http 的版本)。这时候,要么命令执行失败,要么会报出类似 Incompatible target framework 的错误。

编辑 .csproj 手动加 PackageReference 的关键细节

对于追求可控性和自动化的工作流(比如 CI/CD 管道,或者需要统一管理多个项目的依赖版本),直接编辑 .csproj 文件往往是更优选择。不过,这里的 XML 结构和属性含义可马虎不得,一不小心就会导致编译时报 MSB4057 错误,或者引用根本不起作用。

来看一个正确的写法示例:

这条引用必须放在 标签内部,而且这个 ItemGroup 通常应该是 节点的直接子元素,可别把它塞到某个 里面去了。

  • Include 属性里填的是包的 ID,不是 DLL 的文件名,也不是命名空间。举个例子,要安装的是 Microsoft.Data.SqlClient,而不是简单地写个 SqlClient
  • Version 属性强烈建议使用固定值,比如 5.1.5。尽量避免使用通配符像 5.* 这样的写法,因为它在执行包还原(restore)时的行为可能难以预测,在 CI 环境中尤其容易引发问题。
  • 如果需要根据条件来引用包(比如只在 Debug 配置下引入某个测试工具),可以加上 Condition 属性:

dotnet add package 和 VS 图形界面行为为何不一致?

这背后的根本原因,在于两者作用域和默认逻辑的不同。dotnet add package 是命令行工具(CLI)的命令,它只针对当前目录下的那个 .csproj 文件进行操作,不会去读取 Visual Studio 解决方案级别的设置。而 VS 的图形界面则“聪明”得多,它会自动处理项目之间的依赖传递、尝试进行版本对齐(例如统一整个解决方案里 Microsoft.NETCore.App 这种共享框架的版本)。

举个例子:你在解决方案的根目录执行 dotnet add src/MyApp/MyApp.csproj package AutoMapper,这条命令只会更新 MyApp.csproj 文件,它既不会去动其他项目,也不会检查像 Directory.Packages.props 这类文件中定义的全局版本控制规则。

  • CLI 命令默认使用 nuget.org 作为包源。如果想指定其他源,必须通过 --source 参数明确告知,例如:dotnet add package Moq --source https://api.nuget.org/v3/index.json
  • 如果项目文件里设置了 true 来启用锁文件,那么 CLI 命令在添加包时会生成或更新 packages.lock.json 文件。而通过 VS 图形界面操作,这个锁文件不一定会被同步刷新。
  • 当你在 VS 图形界面上点击“更新”按钮时,背后实际调用的可能是 Update-Package 这样的 PowerShell 命令或其内部等效逻辑。它会尝试保留版本号中定义的语义化版本范围(例如 ~3.0.0)。相比之下,CLI 的 dotnet add package 命令则总是简单直接地在 .csproj 里写入一个固定的 Version 属性值。

说到底,在 NuGet 包管理上,真正让人头疼的往往不是“怎么把包装上”,而是“装完之后引用为什么不生效”,或者“为什么在开发机器上好好的,一到构建服务器就出问题”。所以,务必反复确认:PackageReference 是否放在了正确的 ItemGroup 里?有没有被某个 Condition 属性意外地屏蔽掉?而那些更隐蔽的坑,比如私有源的地址是否正确、访问凭据是否有效、企业内网的 TLS 版本是否支持,这些才是最容易卡住团队协作和自动化流程的关键所在。

本文转载于:https://www.php.cn/faq/2333948.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注