看板 DigiCurrency 關於我們 聯絡資訊
根據這個網站說明: https://gitchat.csdn.net/columnTopic/5b0e4011100ce52029ab6f40 以太坊中為了防止交易重播攻擊,每筆 Transaction 都必須 有一個 Nonce 隨機數。每個賬戶從同一個節點發起交易時的 Nonce 值都是從 0 開始,發送一筆 Transaction 後 Nonce 加 1,當 Nonce 為 0 的交易處理完之後,才會處理 Nonce 為 1 的交易,並以此類推。 以下是 Nonce 使用的規則: 當 Nonce 值小於之前 Transaction 的 Nonce 值時, 交易會被直接拒絕; 當 Nonce 值過大時,Transaction 會一直處於隊列之中,等待執行; 假設賬號 C 最後一筆 Transaction 的 Nonce 值為 10,此時 發送一筆 Nonce 值為 13 的 Transaction 至節點中。此筆 交易會一直處於隊列中,不會立即打包上鍊。需要等待 Nonce 值為 11 和 12 的 Transaction 依次執行完後才會來處理這筆 Transaction。 ===== 哇,我的老天,那這樣不是代表一個帳戶越使用,優先級別就越低了? 所以以太坊的用戶交易次數多了,還要換錢包嘛? 這是不是我誤會了什麼? 另外,這個 nonce 值正常人不可能去記他, 基本上要透過 Web3 API 去鍊上取得, 但在製作交易簽名的時候這個值要預先填進去, 這是不是意味著 ETH 其實無法靠冷錢包做離線簽名? -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.169.11.110 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/DigiCurrency/M.1655393771.A.17F.html
rand: nonce 是跟自己比 06/16 23:38
喔,這樣就了解了 不過如果不取得nonce,沒法離線簽名了.... ※ 編輯: overdoingism (118.169.11.110 臺灣), 06/16/2022 23:41:24
rand: nonce 本來就可以手動填 完全離線的狀況就由自己去把 nonce 06/16 23:42
rand: 填上去 06/16 23:42
rand: 給太低的 nonce 會被拒絕 給太高要等前面的執行 06/16 23:43
rand: 最常見的狀況就是 fee 給太低了 06/16 23:51
rand: 用另外一筆同 nonce 但 fee 比較高的交易把它取代掉 06/16 23:51
DarkerDuck: 對啊,要取消交易就是填同一個nonce值的0值交易 06/17 00:09
DarkerDuck: 你的離線簽名是指sign message還是sign transaction? 06/17 00:10
DarkerDuck: 假如是sign message用不到nonce值 06/17 00:13
DarkerDuck: 假如真的要sign一個離線的transaction放很久的話 06/17 00:14
DarkerDuck: 那就開一個account給它專用就不用管nonce值跳動 06/17 00:14
overdoingism: sign transaction 06/17 00:17
overdoingism: 了解 06/17 00:17
MACD: 交易簽名時不用填nonce,送出時會自動抓”確認”tx nonce 06/17 01:42
MACD: 所以如果不是特殊操作重複送tx用比較大的gas price會蓋過 06/17 01:42
MACD: pending tx 06/17 01:42
wlsh5701: 不用填nonce是因為在signTransaction的時候會自動抓吧? 06/17 02:05
wlsh5701: 在對tx簽名時裡面沒有nonce怪怪的 06/17 02:05
JapaZPa4867: 答案文檔和黃皮書裡全都有 請認真閱讀 06/17 05:12
LinuxDapp: 請google 或是自己試 06/19 14:43