调用 ATL COM DLL的几种方法
2015-06-18 10:16
429 查看
需要在VC6.0中调用 ATL COM DLL
用Dependency Walker打开我的ATL COM DLL 发现没有接口。只有这几项:
(1) DllCanUnloadNow
(2) DllGetClassObject
(3) DllRegisterServer
(4) DllUnregisterServer
后来知道,ATL COM 的接口不一定一定全在Dll 中。在网上找到了如下方法。我个人觉得第四种挺好用。
准备及条件:
COM服务器为进程内服务器,DLL名为simpCOM.dll,该组件只有一个接口IFoo,该接口只有一个方法HRESULT SayHello(void)
在SDK中调用
=====================================
一、最简单最常用的一种,用#import导入类型库,利用VC提供的智能指针包装类
演示代码:
#import "D:\Temp\vc\simpCOM\Debug\simpCOM.dll " no_namespace
CoInitialize(NULL);
IFooPtr spFoo = NULL;
spFoo.CreateInstance(__uuidof(Foo));
spFoo-> SayHello();
spFoo.Release();
CoUninitialize();
二、引入midl.exe产生的*.h,*_i.c文件,利用CoCreateInstance函数来调用
演示代码:
#include "D:\Temp\vc\simpCOM\simpCOM.h "
CoInitialize(NULL);
IFoo* pFoo = NULL;
HRESULT hr = CoCreateInstance(CLSID_Foo, NULL, CLSCTX_ALL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo-> SayHello();
pFoo-> Release();
}
CoUninitialize();
三、不用CoCreateInstance,直接用CoGetClassObejct得到类厂对象接口,然后用该接口的方法CreateInstance来生成实例。
演示代码:
IClassFactory* pcf = NULL;
HRESULT hr = CoGetClassObject(CLSID_Foo, CLSCTX_ALL, NULL, IID_IClassFactory, (void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))
{
IFoo* pFoo = NULL;
hr = pcf-> CreateInstance(NULL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo-> SayHello();
pFoo-> Release();
}
pcf-> Release();
}
四、不用CoCreateInstance or CoGetClassObject,直接从dll中得到DllGetClassObject,接着生成类对象及类实例(本方法适合于你想用某个组件,却不想在注册表中注册该组件)
演示代码:
typedef HRESULT (__stdcall * pfnGCO) (REFCLSID, REFIID, void**);
pfnGCO fnGCO = NULL;
HINSTANCE hdllInst = LoadLibrary( "D:\\Temp\\vc\\simpCOM\\Debug\\simpCOM.dll ");
fnGCO = (pfnGCO)GetProcAddress(hdllInst, "DllGetClassObject ");
if (fnGCO != 0)
{
IClassFactory* pcf = NULL;
HRESULT hr=(fnGCO)(CLSID_Foo, IID_IClassFactory, (void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))
{
IFoo* pFoo = NULL;
hr = pcf-> CreateInstance(NULL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo-> SayHello();
pFoo-> Release();
}
pcf-> Release();
}
}
FreeLibrary(hdllInst);
在MFC中调用
=====================================
在MFC中除了上面的几种方法外,还有一种更方便的方法,就是通过ClassWizard利用类型库生成包装类,不过有个前提就是com组件的接口必须是派生自IDispatch
具体方法:
1、按Ctrl+W调出类向导,按Add Class按钮弹出新菜单,选From a type libarary,然后定位到simpCOM.dll,接下来会出来该simpCOM中的所有接口,选择你想生成的接口包装类后,向导会自动生成相应的.cpp和.h文件.
这样你就可以在你的MFC工程中像使用普通类那样使用COM组件了.
演示代码:
CoInitialize(NULL);
IFoo foo;
if (foo.CreateDispatch( "simpCOM.Foo ") != 0)
{
foo.SayHello();
foo.ReleaseDispatch();
}
CoUninitialize();
用Dependency Walker打开我的ATL COM DLL 发现没有接口。只有这几项:
(1) DllCanUnloadNow
(2) DllGetClassObject
(3) DllRegisterServer
(4) DllUnregisterServer
后来知道,ATL COM 的接口不一定一定全在Dll 中。在网上找到了如下方法。我个人觉得第四种挺好用。
准备及条件:
COM服务器为进程内服务器,DLL名为simpCOM.dll,该组件只有一个接口IFoo,该接口只有一个方法HRESULT SayHello(void)
在SDK中调用
=====================================
一、最简单最常用的一种,用#import导入类型库,利用VC提供的智能指针包装类
演示代码:
#import "D:\Temp\vc\simpCOM\Debug\simpCOM.dll " no_namespace
CoInitialize(NULL);
IFooPtr spFoo = NULL;
spFoo.CreateInstance(__uuidof(Foo));
spFoo-> SayHello();
spFoo.Release();
CoUninitialize();
二、引入midl.exe产生的*.h,*_i.c文件,利用CoCreateInstance函数来调用
演示代码:
#include "D:\Temp\vc\simpCOM\simpCOM.h "
CoInitialize(NULL);
IFoo* pFoo = NULL;
HRESULT hr = CoCreateInstance(CLSID_Foo, NULL, CLSCTX_ALL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo-> SayHello();
pFoo-> Release();
}
CoUninitialize();
三、不用CoCreateInstance,直接用CoGetClassObejct得到类厂对象接口,然后用该接口的方法CreateInstance来生成实例。
演示代码:
IClassFactory* pcf = NULL;
HRESULT hr = CoGetClassObject(CLSID_Foo, CLSCTX_ALL, NULL, IID_IClassFactory, (void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))
{
IFoo* pFoo = NULL;
hr = pcf-> CreateInstance(NULL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo-> SayHello();
pFoo-> Release();
}
pcf-> Release();
}
四、不用CoCreateInstance or CoGetClassObject,直接从dll中得到DllGetClassObject,接着生成类对象及类实例(本方法适合于你想用某个组件,却不想在注册表中注册该组件)
演示代码:
typedef HRESULT (__stdcall * pfnGCO) (REFCLSID, REFIID, void**);
pfnGCO fnGCO = NULL;
HINSTANCE hdllInst = LoadLibrary( "D:\\Temp\\vc\\simpCOM\\Debug\\simpCOM.dll ");
fnGCO = (pfnGCO)GetProcAddress(hdllInst, "DllGetClassObject ");
if (fnGCO != 0)
{
IClassFactory* pcf = NULL;
HRESULT hr=(fnGCO)(CLSID_Foo, IID_IClassFactory, (void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))
{
IFoo* pFoo = NULL;
hr = pcf-> CreateInstance(NULL, IID_IFoo, (void**)&pFoo);
if (SUCCEEDED(hr) && (pFoo != NULL))
{
pFoo-> SayHello();
pFoo-> Release();
}
pcf-> Release();
}
}
FreeLibrary(hdllInst);
在MFC中调用
=====================================
在MFC中除了上面的几种方法外,还有一种更方便的方法,就是通过ClassWizard利用类型库生成包装类,不过有个前提就是com组件的接口必须是派生自IDispatch
具体方法:
1、按Ctrl+W调出类向导,按Add Class按钮弹出新菜单,选From a type libarary,然后定位到simpCOM.dll,接下来会出来该simpCOM中的所有接口,选择你想生成的接口包装类后,向导会自动生成相应的.cpp和.h文件.
这样你就可以在你的MFC工程中像使用普通类那样使用COM组件了.
演示代码:
CoInitialize(NULL);
IFoo foo;
if (foo.CreateDispatch( "simpCOM.Foo ") != 0)
{
foo.SayHello();
foo.ReleaseDispatch();
}
CoUninitialize();
相关文章推荐
- Python:xpath备忘
- listview优化(中)
- ThinkPHP查询数据与CURD
- 泛型及其继承和同一性
- umask码和文件权限
- C# WPF ASP.net 上传多文件和数据
- 解析哈希表
- Google Code Jam 2015 R2 C
- jQuery全屏滚动插件fullPage.js
- Class.forName加载mysql驱动总是产生ClassNotFoundException异常
- c++ builder 俩种不同风格的窗体
- java字符串
- idea导入项目出错
- 将本地html文件拖到IE8浏览器无法打开,直接弹出一个下载的对话框
- iOS va_list,va_start,va_end
- 希尔排序
- CRC32算法详细推导(3)
- CRC算法详解(2)
- SYSTEMTAP安装
- UIModalPresentationFormSheet resizing view