gpt4 book ai didi

.net - 无法从 VBA 获得无需注册的 COM

转载 作者:行者123 更新时间:2023-12-02 09:21:09 24 4
gpt4 key购买 nike

更新:在花了 20 多个小时尝试让一个简单的示例工作之后,我意识到这并不像看起来那么简单。文章 like this揭示“陷阱”——这是在 Windows 7 之前编写的(它以不同的方式处理 list )。我坚持将 .NET 程序集暴露给 VBA via VSTO .

<小时/>

我制作了一个简单的 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 的建议更新:

我取消选中“注册 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 上失败,并出现不太有用的错误对象“IActCtx”的方法“CreateObject”失败

sxstrace 显示它读取 client.manifest 并创建激活上下文。 Process Monitor 显示它访问 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,服务器(程序集)和客户端需要位于同一文件夹中。请参阅:

http://msdn.microsoft.com/en-us/magazine/cc188708.aspx

关于.net - 无法从 VBA 获得无需注册的 COM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15503117/

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