(1)利用向导完成DataSnap服务器的框架,如下图:
由于是实验,所以选择VCL程序,如果是实际应用,建议Service程序
我习惯使用TCP/IP作为通讯协议,简单且速度快,Sample Methods是演示和测试用
缺省211端口
使用TDSServerModule作为数据服务提供主体,非常方便变更为Service应用服务
(2)设置服务器数据
在TDSServerModule中设置数据,为简便起见,采用BDE引擎的DBDEMOS下animals.dbf数据库,有文字也有图片,如下图:
放置一个TDataSetProvider连接该数据源,如下图:
服务器至此设计完成,没有编写一行代码,只是调整了部分控件和窗体的名称。手动启动该应用服务程序。
(3)新建Android客户端程序
新建一个android客户端程序,在工程中增加一个TDataModule模块,用于放置与应用服务器的连接和数据,在模块窗体上放置TSQLConnection、TDSPProviderConnection、TClientDataSet三个控件,如下图:
其中TSQLConnection的属性设置中LoginPrompt要设为False,TDSPProviderConnection的属性设置如下:
其中ServerClassName是指应用服务器上作为数据服务提供主体的TDSServerModule的实例类名称,在这里我习惯性地重新命名了,缺省一般是TServerMethods1。TClientDataSet的设置如下图:
为实现应用服务器上Sample Methods在客户端的调用,需要创建服务类在客户端的实现类,右键点击TSQLConnection选择生成,如下图:
新生成的类定义如下:
以上过程完全同Windows下的DataSnap客户端开发。
(4)Android界面显示数据
Android下对数据的显示,与Windows下开发最大的区别是,无法使用TDBEdit一类的数据感应控件,取而代之的是标准控件,通过LiveBindings技术实现数据感应。要实现该过程,首先是在窗体上放置用于数据展示的标准控件,这里采用了TListBox和TGrid,通过TTabControl分开,如下图:
IP和Port输入框是为了更灵活地连接服务器,下面的按钮OnClick事件代码如下:
procedure TfrmMain.Button1Click(Sender: TObject)
var
dm : TdmServerMethodsClient
begin
try
//连接指定IP和Port的应用服务器
dmMain.SQLConn.Close
dmMain.SQLConn.Params.Values['HostName'] := edtIP.Text
dmMain.SQLConn.Params.Values['Port'] := edtPort.Text
try
dmMain.SQLConn.Open
try
//创建应用服务器上的Sample Methods在客户端的实现类
dm := TdmServerMethodsClient.Create(dmMain.SQLConn.DBXConnection)
//执行服务器上的方法
ShowMessage(dm.ReverseString(edtIP.Text))
finally
dm.Free
end
//开启客户端数据集
dmMain.cdsanimals.Close
dmMain.cdsanimals.Open
except
on E: Exception do
ShowMessage(E.Message)
end
finally
dmMain.SQLConn.Close
end
end
RegiterServerClasses方法,是李维程序中自定义的,不是delphi datasnap自带的。
DSServer1,应该是放在TForm4窗口实例中的TDSServer实例,在DataSnap中,DSServer1负责TemployeeVO类实例的自动创建工作。
RegiterServerClasses方法的作用,应该就是把TemployeeVO类和DSServer1实例关联起来。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)