自从Delphi2009添加了JSON这个特性之后,相信很多人都对它十分感兴趣吧,我抽了个空做一个小小的Demo,演示了JSON传递数据的情况。

首先建立一个Server,放入DSServer, DSServerClass, TCPServerTransport各一个,然后把DSServerClass和TCPServerTransport关联到DSServer。再放入 ADOConnection, ADOQuery, DataSetProvider, ClientDataSet各一个,做好关联。这些组件将完成生成XML数据的作用。

做好后界面如图所示:

体验 Delphi2009 的 JSON

然后切换到代码视图,添加一个ServerClass,注意添加支持反射的预处理。

体验 Delphi2009 的 JSON

然后实现这个方法,跟据SQL语句查出数据,然后返回相关的XML。

体验 Delphi2009 的 JSON

编写DSServerClass的OnGetClass事件。

体验 Delphi2009 的 JSON

好了,现在可以编译并执行Server程序。在Server启动着的情况下,进行Client的开发。
首先设计Client的界面,如下图所示:

体验 Delphi2009 的 JSON

注意把SqlServerMethod控件关联到SqlConnection控件上,并且SQlConnection控件的Driver属性设置为DataSnap。其他的数据组件按常规的方法进行关联即可。
编写Call按钮的事件,如下:

体验 Delphi2009 的 JSON

编译并启动Client,然后点击Call按钮,即可看到数据从Server端返回来了。

体验 Delphi2009 的 JSON

到此为止,一个简单的Demo就做好了,但是有一些事情还不简单,如下:
我把Server放到了公网的服务器上,然后用Client去调用,却发生了以下的情况,如图所示,连接超时了

体验 Delphi2009 的 JSON

我找了一下,并没有在DataSnap的组件上找到Timeout属性,但是它内定的Timeout时间实在是太短了,在公网上Call几次,成功的几率大概也就是50%,网络状况稍微差一些,就会超时。
这应该是DataSnap组件有所疏漏吧,至少Timeout属性是必须有的,还需要继续等待相关的补丁。

相关文章:

  • 2021-12-07
  • 2021-10-25
  • 2021-05-24
  • 2021-10-16
  • 2022-02-18
  • 2022-12-23
  • 2021-12-30
  • 2021-07-07
猜你喜欢
  • 2021-09-12
  • 2021-08-11
  • 2021-10-08
  • 2022-01-24
  • 2021-12-14
  • 2022-03-09
相关资源
相似解决方案