无法获取hostura.fody以将DLL嵌入到可执行文件中

Can#39;t get costura.fody to embed dll into exe(无法获取hostura.fody以将DLL嵌入到可执行文件中)
本文介绍了无法获取hostura.fody以将DLL嵌入到可执行文件中的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我尝试将类库的DLL嵌入到我的exe中。 我使用的是visual studio 2019和.NET5。 我在一个解决方案中创建了两个项目 一种是类库(DLL),另一种是控制台应用程序 两者都是针对.Net Core 5的。我选择控制台应用程序作为启动项目。 类库只包含打印问候公共静电问候函数。 我将类库的项目引用到控制台应用程序中,然后在控制台应用程序中只调用了ClassNamespace.Library.hello函数。 当我编译它时,它工作得很好。 然后,我按照他们的自述文件中的描述安装了expura.fody,我通过以下方式将添加到控制台项目:

PM> Install-Package Fody
PM> Install-Package Costura.Fody

然后将I FodyWeavers.xml放入项目文件夹

<Weavers>
  <Costura/>
</Weavers>

之后,我重新生成了项目,它生成了,并且exe正在运行,但是当我从输出目录中删除.dll时,.exe没有运行。

推荐答案

无需任何附加软件包即可完成此操作。 从NET 5开始,您必须设置两个选项。

<PropertyGroup>
    <OutputType>Exe</OutputType>
    <TargetFramework>net5.0</TargetFramework>
    <!-- To publish just a single *.exe file -->
    <PublishSingleFile>true</PublishSingleFile>
    <!-- Specify for which runtime you want to publish -->
    <RuntimeIdentifier>win10-x64</RuntimeIdentifier>
    <!-- Since NET 5 specify this if you want to also pack all external *.dll to your file -->
    <IncludeNativeLibrariesForSelfExtract>true</IncludeNativeLibrariesForSelfExtract>
    <!-- Add trimming for a smaller file size if possible--->
    <PublishTrimmed>true</PublishTrimmed>
</PropertyGroup>

IncludeNativeLibrariesForSelfExtract设置为false

IncludeNativeLibrariesForSelfExtract设置为true

Documentation for publish single file

Documentation for trimming

这篇关于无法获取hostura.fody以将DLL嵌入到可执行文件中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)