我是第一次从事客户端 – 服务器程序的工作,而且我对于我正在做什么的开始感到非常不合适.
我将使用Google Protocol Buffers在我的客户端和服务器之间传输二进制数据.我将使用Python变体.据我所知,基本思想是客户端将序列化数据,将其发送到服务器,然后将数据反序列化.
问题是,我真的不知道从哪里开始将二进制数据发送到服务器.我希望它像HTTP请求一样“简单”,但我一直在谷歌搜索传输二进制数据的方法,并在大量的教程,指南和文档中迷失方向.我甚至无法通过调查HTTP传输来判断我是否正在咆哮错误的树(我希望能够使用它,所以如果需要安全性,我可以将它打败到HTTPS).我真的不想进入套接字编程的水平 – 我想在转向之前使用可用的库. (我也更喜欢标准的Python库,不过如果有完美的第三方库,我会住.)
那么,如果有人有一个很好的起点(或者想要自己解释一下)如何通过Python传输二进制数据的好方法,我将不胜感激.顺便说一下,我正在运行的服务器当前正在使用mod_python运行Apache.
解决方法:
无论何时将二进制数据从一个系统移动到另一个系统,都需要记住几件事.
因为你正在使用python,你可以在这里减少一些松弛(假设客户端和服务器都将在python中)并且只需使用cPickle来序列化你的数据.如果你真的想要二进制文件,你将不得不熟悉python的struct模块(http://docs.python.org/library/struct.html).并学习如何打包/解压缩数据.
我首先会介绍简单的线路协议服务器,直到你克服了网络通信的困难.如果你从来没有这样做过,它会很快混淆.如何发出命令,如何传递数据,如何重新同步错误等…
如果您已经了解客户端/服务器协议设计的基础知识,那么首先在磁盘上练习打包和解压缩二进制结构.对于这样的情况,我也参考了HTTP和FTP的RFC.
——-基于评论的编辑——–
通常,这类事情是通过向服务器发送一个“标题”来完成的,该标题包含文件的校验和以及文件的大小(以字节为单位).请注意,我不是指HTTP标头,您可以根据需要自定义它.事件链需要像这样……
CLIENT: "UPLOAD acbd18db4cc2f85cedef654fccc4a4d8 253521"
SERVER: "OK"
(server splits the text line to get the command, checksum, and size)
CLIENT: "010101101010101100010101010etc..." (up to 253521 bytes)
(server reasembles all received data into a file, then checksums it to make sure it matches the original)
SERVER: "YEP GOT IT"
CLIENT: "COOL CYA"
这是过分简化,但我希望你能看到我在这里谈论的内容.
标签:python,file,http,protocol-buffers,client-server