跳至主要内容
本页面使用机器翻译自英语,可能包含错误或不清楚的语言。如需最准确的信息,请参阅英文原文。由于更新频繁,部分内容可能与英文原文有出入。请加入我们在 Crowdin 上的努力,帮助我们改进本页面的翻译。 (Crowdin translation page, Contributing guide)

Multisig Account Key

AccountKeyWeightedMultiSig 是一种账户密钥类型,包含一个阈值和加权公钥(WeightedPublicKeys),后者包含一个由公钥及其权重组成的列表。

要使与 AccountKeyWeightedMultiSig 关联的账户的交易有效,必须满足以下条件: 已签名公钥的加权和应大于阈值。 _ 无效签名不应包含在交易中。 * 已签名公钥的数量应少于加权公钥的数量。

web3py_ext导入extend,将 web3 扩展为 kaia web3

web3eth_account 导入必要的实用程序

使用 Web3.HTTPProvider 和 RPC 端点定义 web3 连接

此外,您还可以将提供商 URL 从 kairos 更改为 quicknode

使用 **Account.from_key_pair ** 从地址和私钥定义 3 个不同的钱包

创建一个TxType.VALUE_TRANSFER类型的空事务。 您可以使用 empty_tx 工具来获取已填写默认字段的 tx。

创建一个事务,其中包含fromtovalue字段以进行传输。

from:发件人地址,to:接收 kaia 的目标地址。

value 字段表示要发送多少 kaia,您可以使用 Web3.to_peb 工具将 kaia 转换为 peb 单位。

使用 fill_transaction 添加交易的其余字段,如gas 限制Nonce等。 如果您想查看以下内容,可以打印这一行之后的所有字段

用 ** 用户 1 的私人密钥** 签名交易

用 ** 用户 2** 和 ** 用户 3** 私钥签署 signed_tx

向网络发送*已签名的交易,并等待接收,直到交易在区块链中完全执行为止

使用 Account.recover_transactionuser3 的签名交易中恢复 user1 地址

web3_multisig_value_transfer_sign_recover.py

from web3py_ext import extend
from web3 import Web3
from eth_account import Account
from web3py_ext.transaction.transaction import (
empty_tx,
fill_transaction,
TxType
)
from cytoolz import merge
w3 = Web3(Web3.HTTPProvider('https://public-en-kairos.node.kaia.io'))
def web3_tx_sign_recover_multisig():
user1 = Account.from_key_pair(
'0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e',
'0xa32c30608667d43be2d652bede413f12a649dd1be93440878e7f712d51a6768a'
)
user2 = Account.from_key_pair(
'0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e',
'0x0e4ca6d38096ad99324de0dde108587e5d7c600165ae4cd6c2462c597458c2b8'
)
user3 = Account.from_key_pair(
'0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e',
'0xc9668ccd35fc20587aa37a48838b48ccc13cf14dd74c8999dd6a480212d5f7ac'
)
value_transfer_tx = empty_tx(TxType.VALUE_TRANSFER)
value_transfer_tx = merge(value_transfer_tx, {
'from' : user1.address,
'to' : user1.address,
'value' : Web3.to_peb(10, "klay"),
})
value_transfer_tx = fill_transaction(value_transfer_tx, w3)
signed_tx = Account.sign_transaction(value_transfer_tx, user1.key)
signed_tx = Account.sign_transaction(signed_tx.rawTransaction, user2.key)
signed_tx = Account.sign_transaction(signed_tx.rawTransaction, user3.key)
tx_hash = w3.eth.send_raw_transaction(signed_tx.rawTransaction)
tx_receipt = w3.eth.wait_for_transaction_receipt(tx_hash)
print('tx hash: ', tx_hash, 'receipt: ', tx_receipt)
recovered = w3.klay.recover_from_transaction(signed_tx.rawTransaction.hex(), "latest")
print("\nsender", user1.address, "\nrecovered", recovered)
web3_tx_sign_recover_multisig()

output

❯ py web3_multisig_value_transfer_sign_recover.py
tx hash: 0xe5c4f8b3bd90bf86660eff4f6e4b51dec84e49ac50adcfff7ca983dcfb2db31d receipt: AttributeDict({'blockHash': HexBytes('0x8e0df2104f3f829e06a23808563b07b22c729e04285ebe76aad08f0fecfb4183'), 'blockNumber': 150557795, 'contractAddress': None, 'cumulativeGasUsed': 51000, 'effectiveGasPrice': 25000000000, 'from': '0x82C6a8D94993d49cfd0c1D30F0F8Caa65782cc7E', 'gasUsed': 51000, 'logs': [], 'logsBloom': HexBytes('0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000'), 'status': 1, 'to': '0x82C6a8D94993d49cfd0c1D30F0F8Caa65782cc7E', 'transactionHash': HexBytes('0xe5c4f8b3bd90bf86660eff4f6e4b51dec84e49ac50adcfff7ca983dcfb2db31d'), 'transactionIndex': 0, 'type': 0})
sender 0x82C6a8D94993d49cfd0c1D30F0F8Caa65782cc7E
recovered 0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e

让这个页面变得更好