本文へスキップ
このページは英語からの機械翻訳を使用しており、誤りや不明瞭な表現が含まれている可能性があります。最も正確な情報については、オリジナルの英語版をご覧ください。頻繁な更新のため、一部のコンテンツはオリジナルの英語になっている可能性があります。Crowdinでの取り組みに参加して、このページの翻訳改善にご協力ください。 (Crowdin translation page, Contributing guide)

パブリック・アカウント・キー

AccountKeyPublicは、1つの公開鍵を持つアカウントに使用される。 アカウントにAccountKeyPublicオブジェクトがある場合、トランザクションの検証処理は以下のように行われる:

eth_utilsweb3eth_accountから必要なユーティリティをインポートする。

web3をkaia web3に拡張するために、web3py_extからextendをインポートする。

Web3.HTTPProviderとRPCエンドポイントを使用してWeb3接続を定義します。

また、プロバイダのURLをkairosからquicknodeに変更することができます。

マルチシグアカウントのメンバーキーであるAccount.from_key_pairを使用して、秘密鍵からウォレットを定義します。

署名するメッセージを定義する

EIP-191標準と互換性を持たせるために、encode_defunctを使ってメッセージをフォーマットする。

作成したアカウントで取引に署名する

署名とその長さをプリントアウトする

署名されたメッセージからAccount.recover_messageで送信者アドレスを復旧します

web3_public_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_public_value_transfer_message_recover():
user = Account.from_key_pair(
'0xe15cd70a41dfb05e7214004d7d054801b2a2f06b',
'0x0e4ca6d38096ad99324de0dde108587e5d7c600165ae4cd6c2462c597458c2b8'
)
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)
web3_public_value_transfer_message_recover()

output

❯ python web3_public_value_transfer_message_recover.py
0x875445e2197ec28e913a1775a40ca8c5a0a9e1806c72e08e01a54caf2b65640d09ff852643df23277c46469ef7f5e84ed96c5553b6ad648a4255a0c5dca58bdc1c
132
sender 0xe15Cd70A41dfb05e7214004d7D054801b2a2f06b
recovered 0xa2a8854b1802d8cd5de631e690817c253d6a9153

ページを改善してください。