本文欢迎转载,唯请注明出处及作者 blackcolor@263.net
---------------------------------------------------
使用ATL创建进程内组件
一、建立一个进程内组件
1)打开菜单File|New,选择Projects标签,然后选择“ATL COM AppWizard”
2)在Project name栏输入step01,单击ok按钮,在下一个窗口单击Finish按钮
插入对象:
3)打开菜单Insert|New ATL Object,在左边的Category中选择Objects,在右边的
Objects中选择Simple Object,单击“Next”按钮
4)在Names标签中,Short Name栏填写Simple01,不修改其他的属性,单击
“确定”按钮。
加入接口方法:
5)在Workspace的ClassView标签中右击“ISimple01”接口,从弹出的菜单中选择
“Add Method”,在弹出的窗口中,Method Name栏填写GetOSVersion,Parameters
栏填写[out, retval]BSTR * bstrVersion
修改类CSimple01的函数STDMETHODIMP CSimple01::GetOSVersion(BSTR *bstrVersion)如下:
// Simple01.cpp : Implementation of CSimple01
#include "stdafx.h"
#include "Step01.h"
#include "Simple01.h"
// 加入comutil支持
#include <comutil.h>
#pragma comment( lib, "comsupp.lib" )
/
// CSimple01
// 取操作系统信息
STDMETHODIMP CSimple01::GetOSVersion(BSTR *bstrVersion)
{
char szOSVersion[10];
OSVERSIONINFO VersionInformation;
VersionInformation.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
// 关于GetVersionEx请参考MSDN
if(GetVersionEx(&VersionInformation))
{
switch(VersionInformation.dwPlatformId)
{
case VER_PLATFORM_WIN32s:
strcpy(szOSVersion, "WIN32S");
break;
case VER_PLATFORM_WIN32_WINDOWS:
strcpy(szOSVersion, "WIN95/98");
break;
case VER_PLATFORM_WIN32_NT:
strcpy(szOSVersion, "WINNT");
break;
default:
strcpy(szOSVersion, "UnKnown");
break;
}
}
else
{
strcpy(szOSVersion, "Error");
}
*bstrVersion = _com_util::ConvertStringToBSTR(szOSVersion);
return S_OK;
}
编译程序,至此我们建立了一个进程内组件。下面我们编译proxy/stub程序
6)进入“MS DOS”状态,找到Step01的目录,运行nmake step01ps.mk,将创建一个
名为Step01ps.dll动态连接库,此动态连接库将在后面的创建com+应用中使用。
二、建立客户程序
1)打开菜单File|New,选择Projects标签,然后选择“Win32 Console Application”
2)在Project name栏输入Client,单击ok按钮,在下一个窗口单击Finish按钮
新建如下文件,并加入工程:
// Client.cpp 文件
#include <windows.h>
#include <stdio.h>
// 加入comutil支持
#include <comutil.h>
#pragma comment( lib, "comsupp.lib" )
// 包含com的定义文件,以下两个文件从step01中拷贝出来
#include "../step01/step01.h"
#include "../step01/step01_i.c"
void main()
{
ISimple01 * pISimple01=NULL; // 我们定义的接口
BSTR bstrOS;
// 初始化
HRESULT hr = CoInitialize(NULL);
if(FAILED(hr))
{
printf("Coinitialize failed! hr=0x%x", hr);
return ;
}
// 创建COM对象
hr = CoCreateInstance(CLSID_Simple01, NULL, CLSCTX_ALL,
IID_ISimple01, (void **)&pISimple01);
if(FAILED(hr))
{
printf("create com failed! hr=0x%x", hr);
CoUninitialize();
return ;
}
// 获得操作系统
hr = pISimple01->GetOSVersion(&bstrOS);
if(FAILED(hr))
{
printf("pISimple01->GetOSVersion() failed! hr=0x%x", hr);
pISimple01->Release();
CoUninitialize();
return ;
}
char *pszOS;
pszOS = _com_util::ConvertBSTRToString(bstrOS);
printf("The OS is %s/n", pszOS);
// 释放分配的内存
SysFreeString(bstrOS);
delete pszOS;
pISimple01->Release();
CoUninitialize();
return ;
}
三、说明
1)我们的组件可以取得操作系统的版本,之所以用这个功能,在后面的DCOM与COM+的应用中,
可以分辨出该组件有没有正确的运行。
2)对进程内组建我们可以用regsvr32 step01.dll进行注册,而用regsvr32 /u step01.dll注销。
在windows 98下运行我们的Client.exe,可以得到
The OS is WIN95/98
在windows 2000下运行我们的Client.exe,可以得到
The OS is WINNT