我正在使用twisted构建xml rpc服务,我想使用None,就像可以在标准python lib中完成的一样。如何将allow_none传递到xmlrpc服务器的扭曲版本?

编辑

In [28]: sock = rpc.ServerProxy('http://localhost:7080',allow_none=True)

In [29]: sock
Out[29]: <ServerProxy for localhost:7080/RPC2>

In [30]: sock.list_reports()
Out[30]: ['example']

In [31]: sock.run_report('example')
---------------------------------------------------------------------------
Fault                                     Traceback (most recent call last)

reports/<ipython console> in <module>()

/usr/lib/python2.6/xmlrpclib.pyc in __call__(self, *args)
   1197         return _Method(self.__send, "%s.%s" % (self.__name, name))
   1198     def __call__(self, *args):
-> 1199         return self.__send(self.__name, args)
   1200
   1201 ##


/usr/lib/python2.6/xmlrpclib.pyc in __request(self, methodname, params)
   1487             self.__handler,
   1488             request,
-> 1489             verbose=self.__verbose
   1490             )
   1491

/usr/lib/python2.6/xmlrpclib.pyc in request(self, host, handler, request_body, verbose)
   1251             sock = None
   1252
-> 1253         return self._parse_response(h.getfile(), sock)
   1254
   1255     ##


/usr/lib/python2.6/xmlrpclib.pyc in _parse_response(self, file, sock)
   1390         p.close()
   1391
-> 1392         return u.close()
   1393
   1394 ##


/usr/lib/python2.6/xmlrpclib.pyc in close(self)
    836             raise ResponseError()
    837         if self._type == "fault":
--> 838             raise Fault(**self._stack[0])
    839         return tuple(self._stack)
    840

Fault: <Fault 8002: "Can't serialize output: cannot marshal None unless allow_none is enabled">

最佳答案

XMLRPC接受allowNone作为其初始化程序的参数。因此,如果要支持True,请在实例化资源时传递None

from twisted.web.xmlrpc import XMLRPC
resource = XMLRPC(allowNone=True)

关于python - 扭曲的XML-RPC服务器中的allow_none,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3760043/

10-13 01:14