【发布时间】:2013-06-18 22:22:17
【问题描述】:
似乎除了在我的 WAMP 服务器中抛出的任何内容都被 Autobahn 捕获并发送到客户端。这样做有两个问题:a) 如果服务器出现问题,则需要将其登录到服务器上,以便团队修复;b) 这些异常可能非常具有启发性(尤其是来自ORM)并且我不希望它们被转发给恶意的第三方。
我可以阻止这种行为吗?如果可以的话,有没有办法将应该发送给客户端的错误消息显式发送?
【问题讨论】:
似乎除了在我的 WAMP 服务器中抛出的任何内容都被 Autobahn 捕获并发送到客户端。这样做有两个问题:a) 如果服务器出现问题,则需要将其登录到服务器上,以便团队修复;b) 这些异常可能非常具有启发性(尤其是来自ORM)并且我不希望它们被转发给恶意的第三方。
我可以阻止这种行为吗?如果可以的话,有没有办法将应该发送给客户端的错误消息显式发送?
【问题讨论】:
更新答案:
AutobahnPython 默认不再发送回溯。
当调用 Callee 的过程引发异常时,仅转发异常 - 而不是完整的回溯。要启用回溯转发,请在 Callee 的 ApplicationSession 上设置 traceback_app = True。
不推荐使用的答案:以下原始答案仅适用于 AutobahnPython 中的 WAMP v1 代码,该代码已被弃用并删除。
带有 WAMP1 代码的 AutobahnPython 的最新版本是 0.8.15,您可以找到 here 和 here。
您可以覆盖派生自autobahn.wamp.WampProtocol 的类上的onAfterCallError 挂钩(请参阅here 或生成的文档)。
在您的覆盖中,您可以执行自定义日志记录和/或修改错误对象,这是发送给调用者的 WAMP RPC 错误返回的基础。
【讨论】:
includeTraceback = False 来完成。我同意,它可能应该默认关闭。
onAfterCallError 或 includeTraceback。这些方法有改变吗? edit 看起来它们已从存储库中删除,例如wamp1/protocol.py。我们能有一个更新的答案吗?
try:
main()
except Exception, e:
log(str(e))
【讨论】: