【说明】
这个例子答应大家很久了,一直没有时间弄,现在正式结合MyBean插件可以很方便的在客户端共享操作连接,执行数据库的各项工作,屏蔽了底层的通信解码器编码等工作,直接传递Variant,给了开发者足够的领活和自由。
【服务端使用技术】
diocp3:担当底层的通信任务。
qworker/iocpTask:担当业务逻辑的处理工作,diocp3接受数据解码后用qworker/iocpTask将数据包投递出来,这样不用占用通信线程。
qmsgpack:负责将传递的将variant数据打包到流,从流中解码成variant
dataModule:对应连接的对象,方便进行开发。
【客户端】
myBean:制作基于MyBean框架的插件,可以在MyBean的框架模块中直接使用。
RawTcpClient:用于和服务端进行通信,阻塞的tcp客户端,类似IdTcpClient的精简版本,操作容易。
【DEMO使用】
说 明:客户端依赖diocp_bean.dll插件与服务器进行数据交换,DIOCP_DBDEMO.dll是演示窗体插件的宿主。
存放路径:MyBean\samples\diocp-DBDEMO
启动服务:SERVER_EXE\diocp3Server.exe <点击start按钮启动服务>

服务器是基于DIOCP3的。可以在DIOCP3项目中找到源码[diocp3\samples\socket-Coder\DataModuleDEMO]
启动客户端:打开 [simpleConsole.exe], 依次点击下面的按钮就可以看到效果了
【DEMO说明】
服务端处理:
服务端基于DIOCP3通信,该DEMO做了简单的封装,使用户可以专注于逻辑的实现,和客户端交互使用variant类型进行。
dmMain,是和客户端连接想对应的一个对象[和客户端的连接是一对一的关系]。
我在里面稍微做了下逻辑处理的演示:
vData,是客户端传递过来的参数,也是返回给客户端的数据。vData是OleVariant可以容纳任何的数据<配合qmsgPack可以达到任何的数据格式要求>, 如果还达不到你的格式要求,你可以在MyClientContext的dataReceived函数做些修改,下面代码的处理过程依次是:
解压收到的数据->QmsgPack解包->取出客户端传入的参数->调用dmMain.Execute处理逻辑->qmsgPack编码数据->压缩数据->回传数据到客户端
客户端处理:
编译的 DLL 放到和EXE同一个目录下面就可以进行自动加载。
客户端diocp_bean工程中
注册的diocpRemoteSvr插件实现了IRemoteServer接口和IRemoteServerConnector接口,而且该插件为单件模式。其他任何地方调用都只会产生一个连接实例。
演示操作窗体:<服务端是13K的成语记录>
相应按钮代码:
PS: 其他功能大家自己去实现,该文章写了好几个中午,希望对大家有用。
由于qdac开源项目 >=D2007,所以D7下面不能编译服务端,和diocp_bean.项目(你可以在D2007中编译好diocp_bean和服务端工程,其他插件可以在d7中完成)
-----------------------------------------------------------------------------------------------------
MyBean 轻量级配置开源框架 开源地址
<a href="https://git.oschina.net/ymofen/delphi-framework-MyBean">https://git.oschina.net/ymofen/delphi-framework-MyBean</a>
DIOCP3开源地址
<a href="https://github.com/ymofen/diocp3">https://github.com/ymofen/diocp3</a>
qdac项目信息
官方QQ群:250530692
SVN检出地址:
<a href="http://svn.code.sf.net/p/qdac3/code/">http://svn.code.sf.net/p/qdac3/code/</a>
svn://svn.code.sf.net/p/qdac3/code/