合并DLL并更改管理命名空间

问题描述 投票:7回答:2

我想创建一个与第三方dll合并的单个dll。这意味着最终消费者只需要处理1个dll而不是2个。

为了增加,可以说第三方dll是nLog。如何处理合并后的dll的消费者已经将NLog作为项目参考的情况?

理想情况下,我希望能够做的是将项目中的NLog名称空间更改为“XyzNLog”,这意味着用户不需要进行任何别名...任何想法我怎么做?

现在我知道我可以为我的NLog项目添加别名,所以我必须将其称为XyzNLog,但我希望将其转移给合并dll的消费者,以便永远不会发生冲突。

更新 - 解决方案

http://blog.mattbrailsford.com/2010/12/10/avoiding-dependency-conflicts-using-ilmerge/

答对了!因此,通过使用ILMerge,可以将第三方库DLL与Providers自己的DLL合并,这意味着我们将只部署一个DLL。但这不是全部,我们实际上可以更进一步,并告诉ILMerge内化所有依赖项。这样做会将所有第三方类转换为内部,这意味着它们只能在最终的DLL中使用。呜啊!问题解决=)

鉴于此问题,我的dll的消费者也可能有NLog消失...因为我引用的NLog转移到全部内部!这正是我想要的。

有没有人对此有任何反馈或想法?

c# .net dll ilmerge
2个回答
1
投票

我同意Hans的观点,我强烈建议单独注册DLL。

否则,你可能会陷入DLL地狱,这将驱使你的消费者离开。

然后,您可以设计一些聪明的部署方法来检测DLL是否已经注册等。


0
投票

我不得不同意@Hans Passant(以及关于经常讨论的DLL地狱的here's some info),但是既然你已经问了这个问题,我会尝试回答它。

您可以将第三方DLL捆绑为资源。请see this question了解详情。

至于你的其他问题,我只是在你自己的命名空间下暴露第三方DLL中的相关类,并且可能使用扩展方法来提供你想要的任何其他功能。

例如,您可以使用类中的静态方法提供对NLog的Log()方法的访问,例如XyzNLog.Logger.Log(),负责初始化,以及内部,代码内部的任何其他内容(静态构造函数或您想要的任何其他内容)。由于您使用上述方法加载NLog程序集,因此您将是唯一可以直接访问嵌入式NLog程序集的用户,并且用户将无法访问它。现在,您没有从NLog自动暴露所有类的好处,在这种情况下您仍然需要手动公开它们。

编辑:另一种方法是尝试使用ILMerge与/ internalize标志as described here。您可能无法完全解决问题,但请查看at this article,看看您是否可以避免作者描述的陷阱。剧透警报:这并不是所有的桃子都在这个,但它可能会工作,有足够的额外努力。

© www.soinside.com 2019 - 2024. All rights reserved.