您的位置:首页 >c#如何使用NuGet包管理器_c#NuGet包管理器的几种常见写法
发布于2026-05-02 阅读(0)
扫一扫,手机访问

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”窗口倒是有可能出现——不过,这已经是过时的做法了。
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。如果不加,默认安装的就是最新的稳定版(预发布版本会被跳过)。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 环境中尤其容易引发问题。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 这类文件中定义的全局版本控制规则。
--source 参数明确告知,例如:dotnet add package Moq --source https://api.nuget.org/v3/index.json。true 来启用锁文件,那么 CLI 命令在添加包时会生成或更新 packages.lock.json 文件。而通过 VS 图形界面操作,这个锁文件不一定会被同步刷新。Update-Package 这样的 PowerShell 命令或其内部等效逻辑。它会尝试保留版本号中定义的语义化版本范围(例如 ~3.0.0)。相比之下,CLI 的 dotnet add package 命令则总是简单直接地在 .csproj 里写入一个固定的 Version 属性值。说到底,在 NuGet 包管理上,真正让人头疼的往往不是“怎么把包装上”,而是“装完之后引用为什么不生效”,或者“为什么在开发机器上好好的,一到构建服务器就出问题”。所以,务必反复确认:PackageReference 是否放在了正确的 ItemGroup 里?有没有被某个 Condition 属性意外地屏蔽掉?而那些更隐蔽的坑,比如私有源的地址是否正确、访问凭据是否有效、企业内网的 TLS 版本是否支持,这些才是最容易卡住团队协作和自动化流程的关键所在。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9