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

マルチシグ・アカウント・キー

AccountKeyWeightedMultiSigは、閾値とWeightedPublicKeys(公開鍵とその重みからなるリスト)を含むアカウント鍵タイプである。

AccountKeyWeightedMultiSigに関連付けられたアカウントで取引が有効であるためには、 以下の条件を満たす必要がある: 署名された公開鍵の加重和が閾値より大きいこと。 無効な署名はトランザクションに含めるべきでない。 * 署名された公開鍵の数は、weightedPublicKeysの数より少なくなければならない。

Web3jとkaiaライブラリ(web3j-ext)から必要なクラスをインポートする。

指定されたBAOBAB_URLでWeb3jインスタンスを作成する

また、デフォルトのプロバイダーを変更することもできる。 例えば、錬金術のプロバイダーを使う。

3つのmulti-sig credentialsを秘密鍵からロードします。

credentials1の**アドレスを取得する。 このアドレスは、回収されたアドレスを検証するために使用される。

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

ブロック番号をkaiaネットワークの最新ブロックに設定する。

すべての3つのmulti-sig credentialsを順番に使ってメッセージに署名し、署名の出力を文字列として取得します。

3つのメッセージ応答からaddressを回復し、それらを元のfromアドレスと比較する。

Web3jインスタンスをシャットダウンする

SignMsgWithMultiSigExample.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 SignMsgWithMultiSigExample implements keySample {
/**
*
*/
public static void run() throws Exception {
Web3j web3j = Web3j.build(new HttpService(keySample.BAOBAB_URL));
KlayCredentials credentials1 = KlayCredentials.create(keySample.MULTI_KEY_privkey1,
keySample.MULTI_KEY_address);
KlayCredentials credentials2 = KlayCredentials.create(keySample.MULTI_KEY_privkey2,
keySample.MULTI_KEY_address);
KlayCredentials credentials3 = KlayCredentials.create(keySample.MULTI_KEY_privkey3,
keySample.MULTI_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 key 1 : " + response1.getResult());
System.out.println("Result address for key 2 : " + response2.getResult());
System.out.println("Result address for key 3 : " + response3.getResult());
web3j.shutdown();
}
}

output

❯ java SignMsgWithMultiSigExample.java
オリジナルアドレス : 0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e
キー1の結果アドレス : 0x82c6a8d94993d49cfd0c1d30f0f8caa65782cc7e
キー2の結果アドレス :0xa2a8854b1802d8cd5de631e690817c253d6a9153
キー3の結果アドレス : 0xe15cd70a41dfb05e7214004d7d054801b2a2f06b

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