我们正在运行一个 RSK 节点,一些智能合约交易显示内部错误,但与失败require
条件相关的消息并没有出现在这些错误消息中......
我们只看到“内部错误”,无法查看发生了哪个特定错误。
我们正在运行一个 RSK 节点,一些智能合约交易显示内部错误,但与失败require
条件相关的消息并没有出现在这些错误消息中......
我们只看到“内部错误”,无法查看发生了哪个特定错误。
如果您的合约在回复中发出消息,那么您可以使用debug_traceTransaction
.
注意:在debug
RSK 配置中默认启用 RPC 模块,但在公共节点上禁用。
此外,RSK 公共节点不公开此功能,您必须运行自己的节点才能这样做。
以下假设您有一个本地节点运行,并在端口上公开了 RPC 4444
。
首先,您需要debug
在配置文件中启用模块:
modules = [
...
{
"name": "debug",
"version": "1.0",
"enabled": "true",
},
...
]
然后,您可以执行将事务 ID 作为参数传递的 RPC 方法,如下例所示:
curl \
-X POST \
-H "Content-Type:application/json" \
--data '{"jsonrpc":"2.0","method":"debug_traceTransaction","params":["0xa9ae08f01437e32973649cc13f6db44e3ef370cbcd38a6ed69806bd6ea385e49"],"id":1}' \
http://localhost:4444
您将收到以下响应(为简洁起见已截断):
{
...
"result": "08c379a00000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000001e536166654d6174683a207375627472616374696f6e206f766572666c6f770000",
"error": "",
"reverted": true,
...
}
最后,result
从十六进制转换为 ASCII,得到可读的信息:
Ãy SafeMath: subtraction overflow