打印本文 打印本文 关闭窗口 关闭窗口
一个实际的OLE服务器的开发和使用
作者:武汉SEO闵涛  文章来源:敏韬网  点击数2015  更新时间:2009/4/23 18:35:42  文章录入:mintao  责任编辑:mintao

一个实际的OLE服务器的开发和使用

先行知识:Delphi /COM/OLE Automation/ SQL Server

难度:★★☆☆☆

 

在前几篇文章中我们已经讨论过关于VCLOLE的知识。在这篇文章中我们将完成一个比较有实际意义的OLE Automation服务器程序,最后我们把他们封装为Delphi中使用的VCL组件。

首先我们来做一个实际的程序,在它没有变为服务器之前,这是个用来管理客户购买记录的程序(它自己与SQL Server连接),它可以录入和删除客户的购买记录并直观的显示出来,所有的数据都存放在SQL Server中。我们将它做为OLE Automation出于这样一种考虑,假设我们是一家大型的供货公司,我们可能有很多系统需要使用这个客户购买记录程序并用它处理SQL Server中相应的数据,但我们不愿意每次都重复的编写同样的处理代码,我们更希望能把这个处理程序独立出来,并向其它程序提供服务。那么在下面的工作中我们完成了这个服务器程序,界面如下:(注意,这仅仅是一个例子,我们不评价其数据库设计的好坏J)

我们不过多的讨论这个程序的代码(因为这和开发一般的程序没有任何不同,你可以按照最后的地址给我来信索取这篇文章的全部代码)。然后我们来把它变为一个服务器。选择FileàNewàOthersàActiveXàAutomation Object。接下来delphi为我们定义了类型库和实现文件,我们要做的只是在类型库中添加相应的我们要用到的服务器属性和事件。我们简单的给出定义这个OLE Automation功能的接口(来自类型库所产生的Object Pascal代码):

  ICustFormOLE = interface(IDispatch)

    [''''{D7AE75F9-F838-4702-A8EB-EAD0EED242DE}'''']

    function Get_CustName: WideString; safecall;

    procedure Set_CustName(const Value: WideString); safecall;

    function Get_ProductName: WideString; safecall;

    procedure Set_ProductName(const Value: WideString); safecall;

    function Get_ProductNum: Integer; safecall;

    procedure Set_ProductNum(Value: Integer); safecall;

    function Get_Remark: WideString; safecall;

    procedure Set_Remark(const Value: WideString); safecall;

    //下面的方法和属性都对应着原程序中相应的方法和属性

    procedure AddToData; safecall;

    procedure DelData; safecall;

    property CustName: WideString read Get_CustName write Set_CustName;

    property ProductName: WideString read Get_ProductName write Set_ProductName;

    property ProductNum: Integer read Get_ProductNum write Set_ProductNum;

    property Remark: WideString read Get_Remark write Set_Remark;

  end;

 

  ICustFormOLEDisp = dispinterface

    [''''{D7AE75F9-F838-4702-A8EB-EAD0EED242DE}'''']

    property CustName: WideString dispid 201;

    property ProductName: WideString dispid 202;

    property ProductNum: Integer dispid 203;

    property Remark: WideString dispid 204;

    procedure AddToData; dispid 205;

    procedure DelData; dispid 206;

  end;

我们现在回到接口的实现文件,注意代码中的注释,事实上这段代码相当的简单:

unit CustOLEImpUnit;

 

{$WARN SYMBOL_PLATFORM OFF}

 

interface

 

uses

  ComObj, ActiveX, CustViewOLE_TLB, StdVcl,windows;

 

type

  TCustFormOLE = class(TAutoObject, ICustFormOLE)

//注意这里实现了我们在前面定义的ICustFormOLE接口

[1] [2] [3]  下一页

打印本文 打印本文 关闭窗口 关闭窗口