首先在FrontEndServer 安装了SQL Server 2000之前,我们可以使用CDOEX的IDataSource.Open打开用户邮箱的:
_ConnectionPtr pCon = NULL;
CComPtr <CDO::IFolder>pFldr;
CComPtr <CDO::IDataSource>pSource;
hr=pFldr.CoCreateInstance(L"CDO.Folder");
pFldr->get_DataSource(&pSource);
hr=pSource->Open(bstrURLInbox,
(IDispatch*)pCon,
adModeRead,
adFailIfNotExists,
adOpenSource,
bstrUserDomainAccount,
bstrUserPwd);
但是安装了SQL Server之后,MDAC就被更新到了version 2.6!!
由于Microsoft的过错,早期的一些MDAC组件被MDAC 2.6删除或者被覆盖掉了!!
而运行IDataSource.Open,是需要引用MDAC 2.5的这些被删除了的组件的,所以就会报出“Class Not Registered”的错误。
此时,如果运行下面的代码:
Set con = CreateObject("ADODB.Connection") con.Provider = "ADsDSOObject" con.Open "ADs Provider"
最后一行会失败并报错:run-tim error 429 'ActiveX component can't create object'
这种情况被新闻组的人们称之为“ADSI toasting ADO”!!
这就是一个非常严重的问题了。你的要使用到以前的ADO的接口的程序可能都不行了!
所以,安装了SQL Server 2000之后,请一定从下列站点下载最新的MDAC安装包或者补丁。
http://www.microsoft.com/data/download_26sp1.htm
解决这个CDOEX的问题,就是下载并安装了MDAC 2.6 SP1 (2.61.7326.6).exe就可以了。 |