Error: the tx doesn't have the correct nonce.TestRPC/Ganache无法获取nonce

简介: 做一个truffle相关的项目,每次尝试创建交易时,总会有以下的一个错误提示:the tx doesn’t have the correct nonce 完整的一般是这样:Error: the tx doesn't have the correct nonce.

做一个truffle相关的项目,每次尝试创建交易时,总会有以下的一个错误提示:

the tx doesn’t have the correct nonce

完整的一般是这样:

Error: the tx doesn't have the correct nonce. account has nonce of: 14 tx has nonce of: 0

开发环境:

  • Truffle v3.4.7
  • Solidity v0.4.13
  • Npm v5.3.0
  • TestRPC v4.0.1 (Ganache)
  • Metamask v3.9.5

网上查阅并阅读了许多与nonce获取相关的文章,似乎导致这个获得nonce问题的原因,是找不到先前交易的nonce来hash生成新交易的nonce

解决办法:

可以尝试通过你的MetaMask重新连接的Test-RPC:
- 1.选择Main Ethereum Network或者是Localhost 8545以太坊的其他任何网络。
- 2.然后再次选择Localhost 8545

在停止和启动一个新的TestRPC节点之后,大部分情况下可以解决这个问题。

如果还不行那就用MetaMask中的Reset Account按钮,这个按钮擦除当前帐户的交易历史记录,用于计算常用账户的nonce。

注意:正常用户不适用这个特性。

这个只对于重置测试网络并希望继续使用同一帐户的开发人员来说是有用的,这样能使MetaMask相信这个网络ID是新状态下的干净网络。

对于用truffle 4+做truffle开发的用户来说,可能要重新装一下MetaMask。

原文:http://cw.hubwiz.com/card/c/ethereum-FAQ/1/2/1/

另外推荐一些之前的教程:

  • python以太坊,主要是针对python围绕web3.py进行区块链以太坊应用开发的讲解。
  • web3j,主要是针对java和android程序员围绕web3j库进行区块链以太坊开发的讲解。
  • php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和事件等内容。
  • 以太坊开发,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
  • 以太坊教程,主要介绍智能合约与dapp应用开发,适合入门。
相关文章
RuntimeError: a view of a leaf Variable that requires grad is being used in an in-place operation.
RuntimeError: a view of a leaf Variable that requires grad is being used in an in-place operation.
2525 0
|
程序员 Go API
译|Don’t just check errors, handle them gracefully(一)
译|Don’t just check errors, handle them gracefully
82 0
|
Java Go API
译|Don’t just check errors, handle them gracefully(二)
译|Don’t just check errors, handle them gracefully(二)
98 0
成功解决ValueError: Found input variables with inconsistent numbers of samples: [86, 891]
成功解决ValueError: Found input variables with inconsistent numbers of samples: [86, 891]
|
机器学习/深度学习 数据采集
ValueError: Found input variables with inconsistent numbers of samples: [140, 1120] 怎么解决?
这个错误通常发生在机器学习模型的训练中,它表示输入数据的样本数量不一致。在你的情况下,你的输入数据中有两个变量,一个变量的样本数量为140,另一个变量的样本数量为1120,因此这个错误就出现了。 为了解决这个问题,你需要确保所有输入变量的样本数量是相同的。你可以通过以下几种方式来解决这个问题: 检查数据:检查数据是否正确加载,可能会导致数据样本数量不一致。 数据清洗:检查是否有重复的样本或者缺失的样本,如果有则需要对数据进行清洗。 数据对齐:如果你使用了多个数据源,那么你需要对它们进行对齐以确保它们的样本数量一致。 数据重采样:如果数据中有不均衡的样本数量,你可以考虑使用数据重采样方
967 0
syntax error, expect {, actual [, pos 0 at
syntax error, expect {, actual [, pos 0 at
216 0
|
Java Apache
Failed to place enough replicas
如果DataNode的dfs.datanode.data.dir全配置成SSD类型,则执行“hdfs dfs -put /etc/hosts hdfs:///tmp/”时会报如下错误: 2017-05-04 16:08:22,545 WARN org.
3313 0