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

多用户账户密钥

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

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

eth_utilsweb3eth_account 中导入必要的实用程序

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

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

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

使用Account.from_key_pair从私人密钥定义钱包,该密钥是多重签名账户的成员密钥

定义要签署的任何信息

使用encode_defunct对报文进行格式化,使其与 EIP-191 标准兼容。

使用创建的账户签署交易

打印签名及其长度

使用Account.rec recover_message从签名邮件中恢复发件人地址

web3_multisig_value_transfer_message_recover.py

from eth_account import Account
from web3 import Web3
from eth_account.messages import encode_defunct
from eth_utils.curried import to_hex
from web3py_ext import extend
w3 = Web3(Web3.HTTPProvider('https://public-en-kairos.node.kaia.io'))
def web3_multisig_value_transfer_message_recover():
user = Account.from_key_pair(
# multisig account address
'0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e',
# a member key of multisig account
'0xc9668ccd35fc20587aa37a48838b48ccc13cf14dd74c8999dd6a480212d5f7ac'
)
message = to_hex(text="I♥KLAYTN")
msghash = encode_defunct(hexstr=message)
signature = Account.sign_message(msghash, user.key)
print(signature.signature.hex())
print(len(signature.signature.hex()))
recovered = w3.klay.recover_from_message(user.address, message, signature.signature.hex(), "latest")
print("\nsender", user.address, "\nrecovered", recovered) # recovered is an original address of the member key
web3_multisig_value_transfer_sign_recover()

output

❯ python web3_multisig_value_transfer_message_recover.py
0xb7057812498a0a6f740fb218ce5ef945dce3b8437e5662fc707dad72e096b7036f98e96d48dd10de502a1d0ce0ae91e048357721dc7502a9aa2018561c06a97d1b
132
sender 0x82C6a8D94993d49cfd0c1D30F0F8Caa65782cc7E
recovered 0xe15cd70a41dfb05e7214004d7d054801b2a2f06b

让这个页面变得更好