DELPHI 6 抢先研究-- BizSnap/SOAP/WebService 之三 - -- 用 SOAP 实现三层数据库应用
在前面的例子(见
《DELPHI 6 抢先研究 -- BizSnap/SOAP/WebService 之一 -- 一个 Hello world! 的例子》 和《DELPHI 6 抢先研究-- BizSnap/SOAP/WebService 之二 -- 通过 SOAP 传递自定义类型数据》 )
中我们看到了 SOAP 的强大功能,特别是第二个例子。如上一个例子所示,我们只要利用 Midas/DataSnap 的 Provide/Resovle 架构,
将 Data/Delta 包做成自定义类型,在 Web services 与客户端之间传递,便可以通过 SOAP 实现三层数据库应用。
这固然是一个方法,但未免麻烦一些,其实 Delphi 6 早已为我们准备好了,而且她做得更好,她将 IAppServer 接口进行 SOAP 封装,
使得我们可以用和 Midas/DataSnap 一样的方式来开发基于 SOAP 的多层数据库应用。
当然还是以一个例子来说明:
服务端:
1.New|WebServices|Soap Server Application ,如下图:
<img width="443" height="365" alt="" src="/images/illustrations/d6_soap1ide1.jpg"/>
<p>这次我们用 Web App Debugger (详见<a href="/root/entry.php?id=61">《DELPHI 6 抢先研究 -- Web 应用开发及调试》</a>),
设置其 CoClass Name 为 wadSoapDemo3 , 如下图:
<img width="317" height="254" alt="" src="/images/illustrations/d6_soap3ide1.jpg"/>
<p>
2.SaveAll , Unit2 命名为: SvrWMMain , Unit1 不改名, Project1 命名为: Demo3 ; <br/></p><p>
3.New|WebServices|Soap Server Data Module ,如下图: </p>
<img width="443" height="365" alt="" src="/images/illustrations/d6_soap3ide2.jpg"/>
<p>在弹出的对话框中输入 Class Name 为 SoapDemo3DM ,如下图: </p>
<img width="390" height="151" alt="" src="/images/illustrations/d6_soap3ide3.jpg"/>
<p>确定后将此单元保存为 SvrDMSoap ; <br/></p><p>
4.在 SoapDemo3DM 中放入三个控件: SQLConnection1, SQLDataSet1, DataSetProvider1 ,如下图:
其属性设置为:
SQLConnection1 | ConnectionName := IBLocal; LoginPrompt := false; Params.Values[‘Database’] := ‘[…]\Examples\Database\Employee.gdb’; // 上面的 […] 为你的 InterBase 安装路径 |
SQLDataSet1 | SQLConnection := SQLConnection1; CommandText := ‘select EMP_NO, FULL_NAME, PHONE_EXT from EMPLOYEE’; |
DataSetProvider1 | DataSet := SQLDataSet1; |
5.服务端就这样完成了,不用写一行代码,编译并运行,然后退出即完成 Web App Debugger 应用的注册。
启动 Web App Debugger ,再启动浏览器,在地址栏输入: http://localhost:1024/Demo3.wadSoapDemo3/wsdl 即可看到三个接口:
Port Type | Namespace URI | Documentation | WSDL |
IWSDLPublish | urn:WSDLPub-IWSDLPublish | WSDL for IWSDLPublish | |
IAppServer | urn:Midas-IAppServer | WSDL for IAppServer | |
ISoapDemo3DM | urn:SvrDMSoap-ISoapDemo3DM | WSDL for ISoapDemo3DM |
这其中除了有 DataModule 的接口 ISoapDemo3DM 以外,最重要的是多了一个 IAppServer 接口,只要有这个接口,就有 Midas/DataSnap 。
接下来做客户端:
1.New|Application 新建一个一般 VCL 应用程序;
2.SaveAll , Unit1 命名为 ClnMain , Project1 命名为 Client ;
3.在 Form1 上放上 SoapConnection1(在 WebService 页中的最后一个), ClientDataSet1, DataSource1, DBNavigator1, Button1, DBGrid1 等控件,如下图:
设置各自的属性如下表,如果设置正确的话,应该如上图那样在 DBGrid1 中显示出数据来:
SoapConnection1 | URL := 'http://localhost:1024/demo3.wadsoapdemo3/soap'; |
ClientDataSet1 | RemoteServer := SoapConnection1; ProviderName := 'DataSetProvider1'; Active := true; |
DataSource1 | DataSet := ClientDataSet1; |
DBNavigator1 | DataSource := DataSource1; |
DBGrid1 | DataSource := DataSource1; |
Button1 | Caption := 'Apply'; |
4.双击 Button1 输入下面的程序:
procedure TForm2.Button1Click(Sender: TObject);
begin
ClientDataSet1.ApplyUpdates( -1 );
end;
5.至此,客户端程序也完成了,编译并运行(确定 Web App Debugger 已运行),可以看到服务端运行一会儿,
它的窗体闪现几秒钟后客户端程序即可取得数据并显示出来。现在可以通过 DBNavigate/DBGrid 对数据进行操作,
操作完成后按 Apply 按钮即可将数据修改提交到服务端,此操作会运行服务端程序。
就这样,我们只写了一行程序就完成了一个基于 SOAP 的多层数据库应用。