我一直在尝试为基于python组件的WAMP(Web应用程序消息传递协议)调试远程过程调用。例如:
前端(浏览器)
session.call('math.add2', [2, 'two']);
后端(python)
@wamp.register("math.add2")
def add2(self, x, y):
return x + y
它给出了一些关于错误的想法。
对于这样一个简单的例子,它对于拥有大量文件和模块的大型应用程序来说并不重要,我不太确定找出错误的最佳方法,以便输出完整的错误跟踪文件名,行号和描述。
作为解决方案,我稍微修改了 wamp.py (添加了 traceback.print_exc()行,如下所示)以在控制台日志中输出错误:
# autobahn/asyncio/wamp.py
...
import traceback
...
class FutureMixin:
...
@staticmethod
def _as_future(fun, *args, **kwargs):
try:
res = fun(*args, **kwargs)
except Exception as e:
traceback.print_exc() # Added this line
...
这是处理它的标准方法吗?
答案 0 :(得分:2)
AutobahnPython允许您打开WAMP错误消息中的回溯:
class MyComponent(ApplicationSession):
def __init__(self, config = None):
ApplicationSession.__init__(self, config)
self.traceback_app = True