OLE接口用法

原创 2012年03月30日 17:57:33

转载请标明是引用于 http://blog.csdn.net/chenyujing1234

 例子代码:(编译工具:VS2005)

http://www.rayfile.com/zh-cn/files/4468c85c-7a4e-11e1-8329-0015c55db73d/

 

// 第一步得初始化COM环境
	HRESULT hr = CoInitialize(NULL);
	if (FAILED(hr)) 
	{
		return -3;
	}

// 第二步是获得接口 IDccMan
	hr = CoCreateInstance(CLSID_DccMan, NULL, CLSCTX_SERVER, IID_IDccMan, (LPVOID*)&g_pDccMan);
	if (FAILED(hr)) 
	{
		
		return -1;
	}

 


 

	// Create new notification object.
	g_pDanSink = new DanDccSink(hWnd, g_pDccMan);
	if (g_pDanSink)
	{
		// 第三步: 查询IDccManSink的接口
		g_pDanSink->QueryInterface(IID_IDccManSink, (void **)&pdms);

		// 这里调用后会自动调用OnLogActive函数
		g_pDccMan->Advise(pdms, &g_Context);
	}


 

g_pDanSink->QueryInterface(IID_IDccManSink, (void **)&pdms);,

1、会调用DanDccSink::QueryInterface,

STDMETHODIMP DanDccSink::QueryInterface(REFIID riid, LPVOID * ppvObj) 
{
	if (IID_IUnknown == riid || IID_IDccManSink == riid)
	{
		*ppvObj = (IDccManSink*)this;
	}
	else 
	{
		*ppvObj = NULL;
		return E_NOINTERFACE;
	}
	AddRef();

	return NO_ERROR;
}

它返回了(IDccManSink*)this;

 

 

// 第三步:这里调用后会自动调用OnLogActive函数
g_pDccMan->Advise(pdms, &g_Context);

1、它会先调用

STDMETHODIMP_(ULONG) DanDccSink::AddRef(THIS) 
{
	return (ULONG)InterlockedIncrement(&m_lRef);
}



 

2、然后又调用了一次QueryInterface,不过是返回了空接口.

3、调用调用

//
// The connection manager calls OnLogActive to indicate that the connection
// between the PC and the device is up and fully operational.
//
STDMETHODIMP DanDccSink::OnLogActiveC()
{

	return NO_ERROR;
}


4、然后又调用了一次QueryInterface,不过是返回了空接口.
5、然后调用

//
// When a connection is established, the connection manager calls OnLogIpAddr
// to notify you of the IP address of the connected device.
//
STDMETHODIMP DanDccSink::OnLogIpAddr(DWORD dwIpAddr) 
{
	TCHAR szIP[30];
	_stprintf_s(szIP, 30, TEXT("OnLogIpAddr: %02d.%02d.%02d.%02d"),
		(dwIpAddr & 0x000000ff),     (dwIpAddr & 0x0000ff00)>>8, 
		(dwIpAddr & 0x00ff0000)>>16, dwIpAddr>>24);

	//SendMessage(g_hwndStatusBar, SB_SETTEXT, (WPARAM)0, (LPARAM)szIP);

	return NO_ERROR;
}


下午很累了,具体原理下次补充.

 

 

OLE DB 访问接口 "SQLNCLI" 返回了消息

OLE DB 访问接口 "SQLNCLI" 返回了消息--转  (2009-02-25 20:08:02) 转载▼ 标签:  杂谈 分类: SQLSERV...
  • hiyanzi
  • hiyanzi
  • 2014年07月14日 16:51
  • 197

解决MsSQLServer导入数据时遇到【“链接服务器 '(null)' 的 OLE DB 访问接口 'STREAM' 返回了对列 '[!BulkInsert].2SB553' 无效的数据。】

【详细错误】:错误 0xc0202009: 数据流任务 1: SSIS 错误代码 DTS_E_OLEDBERROR。出现 OLE DB 错误。错误代码: 0x80004005。已获得 OLE DB 记...

所有OLE接口

比较有用,记录下来供查阅 常规 函数: lUnknown 目的: 控制的接口协商的对象生存期。普遍存在的任何组件,而不考虑实现。QueryInterface 公开传入的接口。  函数:...

无法执行该操作,因为链接服务器 "xxxxx" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务

一、  问题现象 在执行分布式事务时,在sql server 2005下收到如下错误: 消息 7391,级别 16,状态 2,过程 xxxxx,第 16 行 无法执行该操作,因为链接服务...
  • xyj052
  • xyj052
  • 2012年10月25日 13:37
  • 6295

perl ole接口 API演示介绍

1. perl  ole 接口演示 use Win32::OLE; use Win32::OLE qw(in with); use Win32::OLE::Variant; use Win32...

解决"链接服务器 '(null)' 的 OLE DB 访问接口 'STREAM' 返回了对列 '[!BulkInsert].fieldname' 无效的数据"的一种替换方法

最近在合并两个SQL Server数据库的数据时不幸发生了这种错误,数据只能导入1433条,而其余的上万条数据都无法导入。   我的环境是SQL Server2008 sp1下,使用SQL Serv...
  • Neils03
  • Neils03
  • 2012年01月06日 11:05
  • 9886

OPC(OLE for Process Control)接口技术

  • 2009年12月08日 19:36
  • 5.01MB
  • 下载

链接服务器的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务

一、 问题现象 在执行分布式事务时,在sql server 2005下收到如下错误: 链接服务器"xxxxxxx"的 OLE DB 访问接口 "SQLNCLI" 返回了消息 "没有活动事务。"。 ...

Java 中 Comparable 接口的意义和用法.

在之前的博文中已经介绍了Java中 http://blog.csdn.net/nvd11/article/details/21516075
  • nvd11
  • nvd11
  • 2014年05月29日 23:40
  • 11472
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:OLE接口用法
举报原因:
原因补充:

(最多只允许输入30个字)