役割ベースのアカウント・キー
AccountKeyRoleBasedはロールベースのキーを表す。 アカウントにAccountKeyRoleBasedオブジェクトがあり、トランザクションタイプがアカウント更新を除くものである場合、以下のようにそれぞれのロールに応じたバリデーション処理が行われます:
Web3jとkaiaライブラリ(web3j-ext
)から必要なクラスをインポートする。
指定されたBAOBAB_URLでWeb3jインスタンスを作成する
また、デフォルトのプロバイダーを変更することもできる。 例えば、錬金術のプロバイダーを使う。
それぞれのキー・ペアから異なるロール・ベースの認証情報をロードする。
最初のクレデンシャル**アドレスを取得する。
署名するメッセージを定義する
ブロック番号をkaiaネットワークの最新ブロックに設定する。
3つの役割に基づく資格情報で順番にメッセージに署名し、署名の出力を文字列として取得します
3つのメッセージ応答からaddressを回復し、それらを元のfromアドレスと比較する。
Web3jインスタンスをシャットダウンする
SignMsgWithRoleBasedExample.java
package org.web3j.example.accountKey;import org.web3j.tx.response.PollingTransactionReceiptProcessor;import org.web3j.tx.response.TransactionReceiptProcessor;import org.web3j.example.keySample;import java.io.IOException;import org.web3j.crypto.KlayCredentials;import org.web3j.crypto.KlaySignatureData;import org.web3j.crypto.Sign.SignatureData;import org.web3j.protocol.http.HttpService;import org.web3j.protocol.kaia.Web3j;import org.web3j.protocol.kaia.core.method.response.KlayRecoverFromMessageResponse;/** * */public class SignMsgWithRoleBasedExample implements keySample { /** * */ public static void run() throws Exception { Web3j web3j = Web3j.build(new HttpService(keySample.BAOBAB_URL)); KlayCredentials credentials1 = KlayCredentials.create(keySample.ROLEBASED_KEY_transactionkey, keySample.ROLEBASED_KEY_address); KlayCredentials credentials2 = KlayCredentials.create(keySample.ROLEBASED_KEY_updatekey, keySample.ROLEBASED_KEY_address); KlayCredentials credentials3 = KlayCredentials.create(keySample.ROLEBASED_KEY_feepayer, keySample.ROLEBASED_KEY_address); String from = credentials1.getAddress(); String message = "0xdeadbeef"; String blockNumber = "latest"; SignatureData signature1 = KlaySignatureData.signPrefixedMessage(message, credentials1); String result1 = KlaySignatureData.getSignatureString(signature1); SignatureData signature2 = KlaySignatureData.signPrefixedMessage(message, credentials2); String result2 = KlaySignatureData.getSignatureString(signature2); SignatureData signature3 = KlaySignatureData.signPrefixedMessage(message, credentials3); String result3 = KlaySignatureData.getSignatureString(signature3); KlayRecoverFromMessageResponse response1 = web3j .klayRecoverFromMessage(from, message, result1, blockNumber) .send(); KlayRecoverFromMessageResponse response2 = web3j .klayRecoverFromMessage(from, message, result2, blockNumber) .send(); KlayRecoverFromMessageResponse response3 = web3j .klayRecoverFromMessage(from, message, result3, blockNumber) .send(); System.out.println("Original address : " + from); System.out.println("Result address for transaction key : " + response1.getResult()); System.out.println("Result address for update key : " + response2.getResult()); System.out.println("Result address for feepayer key : " + response3.getResult()); web3j.shutdown(); }}
output
java SignMsgWithRoleBasedExample.java元のアドレス : 0x5bd2fb3c21564c023a4a735935a2b7a238c4cceaトランザクションキーの結果アドレス : 0xe15cd70a41dfb05e7214004d7d054801b2a2f06b更新キーの結果アドレス :0x5bd2fb3c21564c023a4a735935a2b7a238c4cceafeepayer key の結果アドレス : 0xa2a8854b1802d8cd5de631e690817c253d6a9153