我在一个解决方案文件中有 20 个项目。其中 1 个项目是所有项目都引用的标准库项目。
大约一年前,我们添加了一个新的 nuget 包,我们将其命名为Package A
5.0.0.0 版。它有一堆文件,当我们编译时它会到处传输,但我们最终处理了它。我们将包添加到我们的标准库项目(其他 19 个参考)。
我是 Nuget 的新手(所以也许我做错了什么),所以我制作了一个新包作为Package A
. 我已经设置了所有内容,以便帮助程序依赖于Package A
版本 3.0.0.0 到 5.0.0.0(因此它适用于版本低于我们的其他人)。让我们称这个新包Package A helper
我安装Package A helper
并且一切正常。我去做一个拉取请求,我们解决方案中的每个 app.config 现在都有
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Package.A" publicKeyToken="8FC3CCAD86" culture="neutral"/>
<bindingRedirect oldVersion="0.0.0.0-5.0.0.0" newVersion="5.0.0.0"/>
</dependentAssembly>
</assemblyBinding>
</runtime>
如果没有它,它会编译得很好,但 Visual Studio 会抱怨并发出警告。是什么赋予了?我的经理现在不允许我合并我的代码,因为它在 app.config 中添加了太多的噪音并且过于依赖包 A。
为什么Package A
在我们安装之前已经满足主要依赖项时添加依赖的nuget包然后必须有这个新的bindingRedirect Package A Helper
?
为什么当我在 nuget 包和 package.config 中指定 3.0.0.0-5.0.0.0 时它会说 0.0.0.0-5.0.0.0
更新:
当我Package A helper
使用对版本 5.0.0.0 的引用进行构建时,Package A
所有 bindingRedirects 都不会在每个 app.config 中自动填充,而是会生成警告。我最初使用 3.0.0.0 构建它,因为我认为最好以最低依赖性构建它。问题仍然存在,因为 Visual Studio 仍在警告并建议创建 bindingRedirects。
No way to resolve conflict between "Package A, Version=5.0.0.0, Culture=neutral, PublicKeyToken=83hfhsd33" and "Package A, Version=3.0.0.0, Culture=neutral, PublicKeyToken=83hfhsd33". Choosing "Package A, Version=5.0.0.0, Culture=neutral, PublicKeyToken=83hfhsd33" arbitrarily.
Consider app.config remapping of assembly "Package A, Culture=neutral, PublicKeyToken=83hfhsd33" from Version "3.0.0.0" [] to Version "5.0.0.0" [path to Package A dll] to solve conflict and get rid of warning.
解决方案是否只是将我的 nuget 包依赖项从 3.0.0.0 更改为 5.0.0.0 并只允许 5.0.0.0 并摆脱allowedVersions="[3,6)"
我的 packages.config?我不想降低我的 nuget 包的有用性和向后兼容性,但同时我不希望我的主要解决方案需要任何警告或 bindingRedirects。
更新 2:所以Copy Local
在参考属性中设置以False
实际解决我的问题,但我不明白为什么。