[英]Cannot get registration-free COM working from VBA
更新:花了20多个小时试图让一个简单的例子工作,我意识到这并不像看起来那么简单。 像这样的文章揭示了“陷阱” - 这是在Windows 7之前编写的(它以不同的方式处理清单)。 我坚持通过VSTO将.NET程序集暴露给VBA。
我做了一个简单的COM-Visible .NET程序集,我试图从Excel VBA调用它。 如果我在.NET构建期间“注册COM Interop”,我可以成功地从VBA调用它。
Sub VBA()
Dim obj As Object
Set obj = actCtx.CreateObject("ComTest.Main")
MsgBox obj.Test() '<-- Displays "Hello"
End Sub
但是,我想做免注册。
根据Hans的建议更新:
我取消选中Register for COM Interop,并将我的app.Manifest设置为:
<?xml version="1.0" encoding="utf-8"?>
<asmv1:assembly
manifestVersion="1.0"
xmlns="urn:schemas-microsoft-com:asm.v1"
xmlns:asmv1="urn:schemas-microsoft-com:asm.v1"
xmlns:asmv2="urn:schemas-microsoft-com:asm.v2"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<assemblyIdentity
type="win32"
version="1.0.0.0"
name="ComTest"
publicKeyToken="a36a7110110d7bd7" />
<clrClass
clsid="{975DC7E0-4596-4C42-9D0C-0601F86E3A1B}"
progid="ComTest.Main"
threadingModel="Both"
name="ComTest.Main"
runtimeVersion="v4.0.30319">
</clrClass>
<file name = "ComTest.dll"></file>
</asmv1:assembly>
我创建了一个虚拟的“client.manifest”,如下所示:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<asmv1:assembly
manifestVersion="1.0"
xmlns="urn:schemas-microsoft-com:asm.v1"
xmlns:asmv1="urn:schemas-microsoft-com:asm.v1"
xmlns:asmv2="urn:schemas-microsoft-com:asm.v2"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
manifestVersion="1.0"
xmlns="urn:schemas-microsoft-com:asm.v1" >
<assemblyIdentity
name="xxx"
version="1.0.0.0" />
<dependency>
<dependentAssembly>
<assemblyIdentity
type="win32"
name="ComTest"
version="1.0.0.0"
publicKeyToken="a36a7110110d7bd7" />
</dependentAssembly>
</dependency>
</asmv1:assembly>
我在创建对象时修改了我的VBA以使用client.manifest:
Sub VBA()
Dim actCtx As Object
Set actCtx = CreateObject("Microsoft.Windows.ActCtx")
actCtx.Manifest = "C:\Users\me\Desktop\COM Test\ComTest\ComTest\bin\Debug\client.manifest"
Dim obj As Object
Set obj = actCtx.CreateObject("ComTest.Main") '<-- Fails here.
MsgBox obj.Test()
End Sub
它在CreateObject上失败,并且Method 'CreateObject' of object 'IActCtx' failed
。
sxstrace显示它读取client.manifest并创建激活上下文。 进程监视器显示它访问ComTest.dll并在注册表中搜索类975DC7E0-4596-4C42-9D0C-0601F86E3A1B。
我错过了什么?
这是.NET代码:
<ComVisible(True)>
<Guid("EB6AA207-ECC7-413B-9A9B-9D142FF2701D")>
<InterfaceType(ComInterfaceType.InterfaceIsIDispatch)>
Public Interface IMain
Function Test() As String
End Interface
<ComVisible(True)>
<Guid("975DC7E0-4596-4C42-9D0C-0601F86E3A1B")>
<ProgId("ComTest.Main")>
<ClassInterface(ClassInterfaceType.None)>
<ComDefaultInterface(GetType(IMain))>
Public Class Main
Implements IMain
Public Function Test() As String Implements IMain.Test
Return "HELLO"
End Function
End Class
我正在运行64位Windows 7。
要使用免注册COM,服务器(程序集)和客户端都需要位于同一文件夹中。 看到:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.