DataSnap初步二

转:https://blog.csdn.net/a00553344/article/details/51670486

1. 一个典型的DataSnap服务器至少需要三个控件:

TDSServer: DataSnap的逻辑核心控件,控制服务器的运行。

TDSServerClass: DataSnap服务端服务导出控件,通过OnGetClass事件来导出服务端的类及方法供客户端的远程调用。

         作为服务端导出给客户端远程调用的类需要满足以下两个条件:

                   从TComponent类派生。

                   需要有{$METHODINFOON}指令。

一个通讯控件:采用TCP的话,选用TDSTCPServerTransport控件,采用HTTP的话,选用IDSHTTPService控件。

2. 客户端利用一个TSQLConnection控件,Driver设置为Datasnap后,点右键就可以从服务端导入可以远程调用的类及方法。

这一篇详细描述如何利用delphi提供的向导自动创建一个DataSnap服务器。

File > New > Other > DelphiProjects [or C++Builder Projects] > DataSnap Server > DataSnap Server

 

1.      三种选择:

Forms Application : 标准的Forms类型V应用程序。
Console Application: 工作台应用程序。
Service Application: 服务类型的应用程序。
这里选择第一种Forms Application

2.      二种选择:

 

VCL application : 传统的VCL框架
FireMonkey application: 跨平台的FireMonkey框架
这里选择VCL application,因为DataSnap服务端通常运行在Windows服务器上,所以选择VCL框架即可。

3. 这里包括通讯协议、远程调用是否需要授权。。。。等等,这里先按默认的设置。

 

Protocols:服务端和客户端之间的通讯协议。这里可以多选,表示服务端同时支持多种通讯协议。
Authentication:授权或验证。如果勾选,表示客户端连接到服务端的时候需要身份验证。带有Authentication的服务端会增加一个验证控件TDSAuthenticationManager。
Server Methods Class:服务器方法类,由服务端导出给客户端远程调用。通常服务端要实现的供客户端远程调用的函数及方法都会放在这个类里面,再通过TDSServerClass的OnGetClass事件导出给客户端远程调用。
Filters:在客户端和服务端之间过滤(加密或是压缩)数据。勾选后,通常会在TDSTCPServerTransport和IDSHTTPService控件的Filters属性中增加加密和压缩的项。注意除了设置服务端TDSTCPServerTransport和IDSHTTPService控件Filters属性外,也需要在客户端指定一个相应的过滤器。
JavaScript Files:在生成DataSnap REST Server的时候,生成JavaScript接口文件,供客户端调用使用。
Mobile Connectors:提供移动端调用服务端导出类的一些接口文件。
4. 选择TCP的通讯端口,按默认设置。

 

5. 用于远程调用的服务器端函数方法所在类的实现方式(继承方式,从不同的祖先类继承,具备了不同的功能)。

 

TComponnet:从TComponent类继承,所有导出给客户端使用的功能都需要进一步具体实现,因为TComponent类几乎不提供什么功能。
TDataMoudle: 从TDataMoudle类继承,可以放入非可视化控件,比如数据库访问控件。这样,服务端就可以直接利用这些控件访问数据库服务器。但是,访问数据库的连接,数据和数据集不同直接导出给客户端使用,需要服务端进一步实行将数据传输给客户端使用。
TDSServerModule: 从TDSServerModule类继承,它既包含了TDataModule的功能,又可以直接将与数据库服务器的连接和数据集直接暴露给客户端调用,客户端可以非常方便的通过DataSnap服务端直接访问数据库服务器。这个方式广泛应用于客户端是移动端的应用中,因为访问各种数据库需要数据库客户端的驱动或是函数,移动端通常都没有或是安装不了这些数据库客户端驱动,所以将这些数据库客户端驱动都安装到DataSnap服务端上去,由DataSnap服务端来实现数据的访问和存取,而客户端则直接使用DataSnap服务端导出的数据库连接和数据集来访问和存取数据库,同时客户端并不需要安转各种数据库的客户端驱动。
 

6. 选择Finish,这样一个DataSnapServer就建立了。
————————————————
版权声明:本文为CSDN博主「a00553344」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/a00553344/article/details/51670486

猜你喜欢

转载自www.cnblogs.com/railgunman/p/11456252.html