gpt4 book ai didi

.net - 为什么 regasm 会警告我使用强名称签名?

转载 作者:行者123 更新时间:2023-12-04 11:15:27 26 4
gpt4 key购买 nike

如果我想让 .NET 程序集可用作 COM 服务器,我必须添加一组属性,然后使用 regasm将其注册为 COM 服务器。

如果程序集没有使用强名称签名 regasm当使用 /codebase 运行时键显示 RA0000警告说该程序集可能会干扰同一台计算机上的其他程序集,我应该使用强名称对其进行签名,但注册成功,它甚至可以正常工作。

AFAIK 强名称旨在防止所谓的 DLL hell 。但 COM 也旨在防止 DLL hell 。如果我更改任何暴露给 COM 的接口(interface),我必须要么更改 GUID,要么至少保持二进制兼容性。所以用强名称签名似乎并没有增加任何有用的东西——没有什么能阻止我破坏 COM 接口(interface),然后用相同的 key 对签名并拥有成熟的 DLL hell 。

在 COM 公开的 .NET 程序集的情况下,使用强名称签名有什么用?

最佳答案

这是一个笨拙的警告。 COM DLL Hell 有两个方面。真正糟糕的是修改公共(public)接口(interface)而不是分配新的 GUID。未重新编译的客户端应用程序在调用完全错误的方法或使用令人讨厌的 AccessViolationException 炸弹时往往会崩溃和烧毁,根本不知道原因可能是什么。

第二个是做所有正确的事情(分配新的 GUID),然后用新版本覆盖现有的 DLL。您仍然会崩溃该陈旧的客户端应用程序,但更温和的是 E_NOINTERFACE hresult 会生成一个非常具体的异常来帮助您诊断原因。不过,用户并没有更快乐。

该场景在 .NET 中有现成的解决方案,GAC 支持并行部署具有不同版本号的程序集,以便旧版本和新版本可以共存,并且过时的客户端应用程序继续对旧版本感到满意版本。这需要一个强名称。是的,当您使用/codebase 时,该警告肯定会被抑制,因为这清楚地表明您不会使用 GAC。尽管在使用/codebase 时稍微调整一下你的 Nose 并没有什么坏处。此外,您永远不会在测试时在您的开发机器上使用 GAC,但在部署时当然应该考虑它。

关于.net - 为什么 regasm 会警告我使用强名称签名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4864892/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com