在用python的SimpleXMLRPCServer模块使客户端调用服务端函数的时候出现了一些问题,原因是我希望能将file类型的文件对象传输到服务端,这样服务端就可以往里面写内容,最后return回来,实现一种文件传输功能,然而,python始终会出一个error.
很明显,file类型的对象没法被marshal,继而没法传输。
这让我想到之前用Java的RMI实现几乎一样的内容并没有什么不妥。类似的远程调用协议,传输之前需要marshal应该都是必须的步骤。
于是去查了下,RMI的远程调用的参数确实都是需要是Serializable的,然后在通过marshal之后传输到服务端,而且还特别提到了大部分java类都是Serializable,
java.io.file是特例,这让我更加困惑了,显然实际的代码运行顺利,于是再去看看API,结果猛然发现,在1.7中file已经是Serializable的。不知道那个版本开始改动的。
这样一切都说的通了,就是RPC的问题没解决,没法直接传文件对象就只好想想其他办法了。