我有一个视觉工作室的解决方案。 我在解决方案中有许多项目。 有一个主要项目作为启动,并使用其他项目。 有一个项目叫“ProjectX”。其参考资料添加到主项目中。 ProjectX引用了另一个. net dll(例如abc.dll),它不是解决方案的一部分。
现在这个abc.dll应该被复制到主项目的bin/debug文件夹中,但它没有被复制到那里。为什么没有被复制,有什么已知的原因吗?
我有一个视觉工作室的解决方案。 我在解决方案中有许多项目。 有一个主要项目作为启动,并使用其他项目。 有一个项目叫“ProjectX”。其参考资料添加到主项目中。 ProjectX引用了另一个. net dll(例如abc.dll),它不是解决方案的一部分。
现在这个abc.dll应该被复制到主项目的bin/debug文件夹中,但它没有被复制到那里。为什么没有被复制,有什么已知的原因吗?
当前回答
除了上述常见的解决方案,我还有一个多项目解决方案要发布。显然,一些文件针对不同的框架。
所以我的解决方案:属性>特定版本(假)
其他回答
不确定这对我是否有帮助,但我多次引用DLL(当然会自动将其添加到bin文件夹中)。然而,DLL可能需要额外的DLL(取决于我使用的函数)。我不想在我的项目中引用那些,因为它们只需要在我实际使用的DLL相同的文件夹中结束。
我在Visual Studio中通过“添加一个现有文件”来实现这一点。您应该能够将它添加到除Add_data文件夹之外的任何地方。就我个人而言,我只是把它加到根上。
然后将该文件的属性更改为…
Build Action = None(将此设置为Content之类的内容实际上是将“根”版本复制到根,并在Bin中添加一个副本)。
复制到输出文件夹=如果更新则复制(基本上只在它丢失时才将其放在BIN文件夹中,但在那之后就不会这样做)
当我出版…我添加的DLL只存在于BIN文件夹中,而在发布位置(这是我想要的)中没有其他地方。
是的,您需要将“本地复制”设置为true。但是,我非常确定您还需要从主项目引用该程序集,并将Copy Local设置为true—它不仅仅是从依赖的程序集复制。
您可以通过单击References下的程序集并按F4来获得Copy Local属性。
TLDR;Visual Studio 2019可能只是需要重新启动。
我在使用基于Microsoft.NET.Sdk项目的项目时遇到了这种情况。
<Project Sdk="Microsoft.NET.Sdk">
具体地说:
Project1: targets.netstandard2.1 通过Nuget引用Microsoft.Extensions.Logging.Console projec2: targets.netstandard2.1 通过项目引用引用Project1 Project2Tests: targets.netcoreapp3.1 通过项目引用引用Project2
在测试执行时,我收到了错误消息,指出无法找到Microsoft.Extensions.Logging.Console,并且它确实不在输出目录中。
我决定通过将Microsoft.Extensions.Logging.Console添加到Project2中来解决这个问题,结果发现Visual Studio的Nuget Manager并没有列出安装在Project1中的Microsoft.Extensions.Logging.Console,尽管它存在于Project1中。csproj文件。
简单地关闭并重新启动Visual Studio就解决了这个问题,而不需要添加额外的引用。也许这将为某人节省45分钟的生产力损失:-)
当您将其设置为程序集属性时,它看起来很流畅
[AttributeUsage(AttributeTargets.Assembly)]
public class ForceAssemblyReference: Attribute
{
public ForceAssemblyReference(Type forcedType)
{
//not sure if these two lines are required since
//the type is passed to constructor as parameter,
//thus effectively being used
Action<Type> noop = _ => { };
noop(forcedType);
}
}
用法如下:
[assembly: ForceAssemblyReference(typeof(AbcDll.AnyClass))]
您可以将主项目和ProjectX的构建输出路径设置为相同的文件夹,然后您可以在该文件夹中获得所需的所有dll。