Python transfer file through xmlrpc
2010-12-26 11:02
218 查看
实际操作中经常要在两个计算机之间传输文件并完成一些处理,共享文件夹只能存在一个固定的地方,FTP则需要单独下载软件,用python写了一个脚本,利用xmlrpc特性传输文件。
传输中要用xmlrpclib.Binary包装数据,接收端需要用Binary.data返回原始数据并保存。
Server
----------------------------------------------------------------------------------
from SimpleXMLRPCServer import SimpleXMLRPCServer
import xmlrpclib
def filesave(file,binary):
print file
f = open(file, "wb")
f.write(binary.data)
f.close()
def test():
return 'test'
server = SimpleXMLRPCServer(("", 8000),allow_none=True)
print "Listening on port 8000..."
server.register_function(filesave, 'save')
server.register_function(test, 'test')
server.serve_forever()
Client
----------------------------------------------------------------------------------
import xmlrpclib
proxy = xmlrpclib.ServerProxy("http://192.168.0.100:8000/")
f= open("d:/tmp/New Text Document.txt", "rb")
print proxy.test()
print proxy.save('d:/tmp/xxx.data',xmlrpclib.Binary(f.read()))
以上只是一个简单的demo,用来上传文件到Server端,可以指定文件在Server端的保存路径,如果从服务器下载文件,则可以参考python xmlrpclib自带的示例。
用xmlrpc传文件不能传送大文件,报错:bufffer not enough,可以把文件分割并用多线程传输,下一步继续完善这个脚本。
传输中要用xmlrpclib.Binary包装数据,接收端需要用Binary.data返回原始数据并保存。
Server
----------------------------------------------------------------------------------
from SimpleXMLRPCServer import SimpleXMLRPCServer
import xmlrpclib
def filesave(file,binary):
print file
f = open(file, "wb")
f.write(binary.data)
f.close()
def test():
return 'test'
server = SimpleXMLRPCServer(("", 8000),allow_none=True)
print "Listening on port 8000..."
server.register_function(filesave, 'save')
server.register_function(test, 'test')
server.serve_forever()
Client
----------------------------------------------------------------------------------
import xmlrpclib
proxy = xmlrpclib.ServerProxy("http://192.168.0.100:8000/")
f= open("d:/tmp/New Text Document.txt", "rb")
print proxy.test()
print proxy.save('d:/tmp/xxx.data',xmlrpclib.Binary(f.read()))
以上只是一个简单的demo,用来上传文件到Server端,可以指定文件在Server端的保存路径,如果从服务器下载文件,则可以参考python xmlrpclib自带的示例。
用xmlrpc传文件不能传送大文件,报错:bufffer not enough,可以把文件分割并用多线程传输,下一步继续完善这个脚本。
相关文章推荐
- < Python >xmlrpclib
- 使用python xml-rpc client & server 来提供metaweblog服务
- How to send custom http_headers for RPC calls using python xmlrpclib?
- Python RPC 之 xml-rpc
- python-文件,目录,file,xml,dir
- Python、PHP通过xml-rpc进行通信,xml-rpc中文的解决
- python项目练习八:使用XML-RPC进行远程文件共享
- python远程调用rpc模块xmlrpclib
- Python、PHP通过xml-rpc进行通信,xml-rpc中文的解决
- python使用SimpleXMLRPCServer实现简单的rpc
- 20.23. xmlrpclib — XML-RPC client access — Python v2.7.5 documentation
- python项目练习八:使用XML-RPC进行远程文件共享
- Python、PHP通过xml-rpc进行通信,xml-rpc中文的解决
- Python 使用XML-RPC进行文件共享
- xml rpc SimpleXMLRPCServer [python]
- Python项目8:使用XML-RPC进行文件共享
- python,wxpython,xmlrpclib,win32api
- python 的SimpleXMLRPCServer,xmlrpclib
- linux 下 rpc python 实例之使用XML-RPC进行远程文件共享
- Insert Element In XML File by Python xml.etree.ElementTree Module