程序集生成失败 - 引用程序集“Interop.Office”没有强名称

时间:2011-07-27 13:53:40

标签: c# wpf interop winforms-interop

我有一个WPF 4项目,用于与VS2010中生成的word文档进行交互,以及一个win form User Control项目,用于将word应用程序托管到其中。和其他com dlls。所有的com dlls都被引用到我的主要wpf应用程序中。我想发布我的项目,以便我可以在另一台机器上安装并执行自动更新,我得到错误:“程序集生成失败 - 引用程序集'Interop.Office'没有强名称。”每个COM Dll的错误。 一个DLL引用(Interop.word.dll,interop.office.dll,interop.VBIDE.dll),所有这些dll也引用并用于我的wpf代码。

我发现Strong Signed Assemblies链接有相同的问题,但它没有解决问题。

3 个答案:

答案 0 :(得分:17)

我花了一段时间在网上搜索这个,我相信你需要的答案可能就在这里,对于大多数第三方dll来说。

"Adding Strong Name to Interop DLL"

本文介绍了向第三方程序集添加强名称的三种方法。命令是:
1.通过密钥对添加强名称

> SN -k MyKeyPair.snk
> ILDASM ASQLService.dll /out:ASQLService.il
> ILASM ASQLService.il /dll /resource=ASQLService.res /key=MyKeyPair.snk

2。通过证书存储中的证书添加强名称

> ILDASM ASQLService.dll /out:ASQLService.il  
> MAKECERT -ss MyCertificateStore -sk MyKeyContainer
> ILASM ASQLService.il /dll /resource=ASQLService.res /key=@MyKeyContainer

3。通过个人信息交换(.pfx)文件中的证书添加强名称

> MAKECERT -r -pe -sv MyCertificate.pvk MyCertificate.cer
> PVK2PFX -pvk MyCertificate.pvk -pi qwerty -spc MyCertificate.cer -pfx MyCertificate.pfx
> SN -p MyCertificate.pfx MyCertificate-publickey.snk
> ILASM ASQLService.il /dll /resource=ASQLService.res /key=MyCertificate-publickey.snk
> SN -R ASQLService.dll MyCertificate.pfx

希望有所帮助

答案 1 :(得分:7)

这个评论应该是一个答案:

  

实际上,如果您决定签名,“强名”问题只会起作用   你的程序集,从那以后它将需要所有引用的dll   强名也签了

如果您不想签署程序集并希望克服此编译错误。选择不签署您要构建的程序集。随后所有项目参考都不需要签名。

答案 2 :(得分:5)

您必须拥有.snk

右键点击您的项目 - >属性并继续签名选项卡 - >检查签署程序集 - >选择新密钥

希望有所帮助