远程调用的序列化问题

在用python的SimpleXMLRPCServer模块使客户端调用服务端函数的时候出现了一些问题,原因是我希望能将file类型的文件对象传输到服务端,这样服务端就可以往里面写内容,最后return回来,实现一种文件传输功能,然而,python始终会出一个error.

pyRPC

很明显,file类型的对象没法被marshal,继而没法传输。

这让我想到之前用Java的RMI实现几乎一样的内容并没有什么不妥。类似的远程调用协议,传输之前需要marshal应该都是必须的步骤。

于是去查了下,RMI的远程调用的参数确实都是需要是Serializable的,然后在通过marshal之后传输到服务端,而且还特别提到了大部分java类都是Serializable,

java.io.file是特例,这让我更加困惑了,显然实际的代码运行顺利,于是再去看看API,结果猛然发现,在1.7中file已经是Serializable的。不知道那个版本开始改动的。

这样一切都说的通了,就是RPC的问题没解决,没法直接传文件对象就只好想想其他办法了。

转载于:https://my.oschina.net/zhudibrian/blog/97067

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值