当前位置:编程学习 > C#/ASP.NET >>

Oralce 调用Delphi写DLL去访问C# WebService

我想从Oracle的存储过程通过一个外部dll(Delphi编写)去访问C#写的WebService时,出现了“尚未调用 CoInitialize”
不知道是怎么回事,望各位指点一二。 --------------------编程问答-------------------- 存储过程 CALL 外部dll?

你厉害。

分两步走吧:
建立测试的独立EXE, CALL 外部DLL 看是否成功;
建立测试DLL, 存储过程 CALL 测试DLL看是否成功;

--------------------编程问答--------------------   这个一般是在使用COM或者调用ADO控件时出现的错误,通常情况下都是程序的问题。调用了com,ole函数库前就要coinitialize,因为在应用程序中,delphi会自动在initialize 单元加上对co...函数的调用,在dll中要自己调用。
    但在Delphi开中的PubDBConn中的如下代码竞也提示“尚未调用 CoInitialize”

procedure CreateadocSQL;
begin
  adocSQL := TADOConnection.Create(nil);
  try
    if adocSQL.Connected then
      adocSQL.Close;
    adocSQL.ConnectionString := StrIS;
    adocSQL.LoginPrompt := FALSE;
    adocSQL.Connected := TRUE;
    adocSQL.CommandTimeout := 600;
  except
    on e: EOleException do
      Application.MessageBox(PChar(e.Source), PChar(e.Message), MB_OK + MB_ICONSTOP);
  end;
end;

initialization      

  CreateadocSQL;
end.

    最终在CreateadocSQL前后加上CoInitialize(nil)和CoUninitilize(),即

try  
  coinitialize(nil);  
  ....  
  finally  
  .....  
  couninitialize;  
  end;

    当然单元中要uses   activex。
补充:.NET技术 ,  C#
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,