7

我们正在运行一个 RSK 节点,一些智能合约交易显示内部错误,但与失败require条件相关的消息并没有出现在这些错误消息中......

我们只看到“内部错误”,无法查看发生了哪个特定错误。

4

1 回答 1

6

如果您的合约在回复中发出消息,那么您可以使用debug_traceTransaction.

注意:debugRSK 配置中默认启用 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
于 2021-02-11T11:29:36.317 回答