中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中怎么生成比特幣錢包地址

發布時間:2021-07-02 14:05:18 來源:億速云 閱讀:297 作者:Leah 欄目:互聯網科技

Java中怎么生成比特幣錢包地址,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

什么是比特幣地址?

比特幣地址是一個隨機查找的十六進制字符串,在比特幣網絡中用于發送和接收比特幣。它是公私不對稱ECDSA密鑰的公共部分。相應的私鑰用于簽署比特幣交易,作為交易時來自你的確認和證明。

從技術上講,比特幣地址是從ECDSA密鑰的公共部分生成的,使用SHA-256RIPEMD-160進行hash,如下文所述,處理得到的結果hash,最后使用Base58校驗編碼對密鑰進行編碼。

讓我們看看如何使用JCE(java加密擴展),Bouncy Castle(RIPEMD-160)以及最后在bitcoinj庫中使用Base58編碼功能來完成所有這些工作。

生成ECDSA密鑰對

我們之前已經介紹過生成RSA公鑰和私鑰。比特幣使用ECDSA代替RSA作為關鍵算法。它生成如下:

Elliptic Curve算法創建KeyPairGenerator

KeyPairGenerator keyGen = KeyPairGenerator.getInstance("EC");

使用指定橢圓曲線是secp256k1。

ECGenParameterSpec ecSpec = new ECGenParameterSpec("secp256k1");
keyGen.initialize(ecSpec);

一旦獲得KeyPairGenerator后,你可以創建KeyPair即密鑰對,從中可以獲取公鑰和私鑰。

KeyPair kp = keyGen.generateKeyPair();
PublicKey pub = kp.getPublic();
PrivateKey pvt = kp.getPrivate();

ECDSA私鑰

你可以只存儲密鑰的私有部分,因為公鑰可以從私鑰派生。

ECPrivateKey epvt = (ECPrivateKey)pvt;
String sepvt = adjustTo64(epvt.getS().toString(16)).toUpperCase();
System.out.println("s[" + sepvt.length() + "]: " + sepvt);

靜態方法adjustTo64()僅填充帶有前導0的十六進制字符串,因此總長度為64個字符。

static private String adjustTo64(String s) {
    switch(s.length()) {
    case 62: return "00" + s;
    case 63: return "0" + s;
    case 64: return s;
    default:
        throw new IllegalArgumentException("not a valid key: " + s);
    }
}

這是由上面的代碼生成的示例私鑰。

s[64]: 024C8E05018319CED4BB04E184C307BFF115976A05F974C7D945B5151E490ADE

這個值通常是由數字錢包存儲的值。

ECDSA公鑰

上面生成的密鑰的公共部分被編碼為比特幣地址。首先,ECDSA密鑰由橢圓曲線上的點表示。該點的X和Y坐標包括公鑰。它們在開頭與“04”連接在一起代表公鑰。

ECPublicKey epub = (ECPublicKey)pub;
ECPoint pt = epub.getW();
String sx = adjustTo64(pt.getAffineX().toString(16)).toUpperCase();
String sy = adjustTo64(pt.getAffineY().toString(16)).toUpperCase();
String bcPub = "04" + sx + sy;
System.out.println("bcPub: " + bcPub);
# prints
bcPub: 04CAAA5C0BDDAA22C9D3C0DDAEC8550791891BB2C2FB0F9084D02F927537DE4F443ACED7DEB488E9BFE60D6C68596E6C78D95E20622CC05474FD962392BDC6AF29

執行SHA-256和RIPEMD-160哈希

我們現在需要在公鑰上執行SHA-256,然后是RIPEMD-160

MessageDigest sha = MessageDigest.getInstance("SHA-256");
byte[] s1 = sha.digest(bcPub.getBytes("UTF-8"));
System.out.println("  sha: " + bytesToHex(s1).toUpperCase());
# prints
  sha: 7524DC35AEB4B62A0F1C90425ADC6732A7C5DF51A72E8B90983629A7AEC656A0

我們使用Bouncy Castle提供程序來執行RIPEMD-160,因為JCE沒有實現此算法。

MessageDigest rmd = MessageDigest.getInstance("RipeMD160", "BC");
byte[] r1 = rmd.digest(s1);

接下來,我們需要在哈希開頭添加一個0x00的版本字節。

byte[] r2 = new byte[r1.length + 1];
r2[0] = 0;
for (int i = 0 ; i < r1.length ; i++) r2[i+1] = r1[i];
System.out.println("  rmd: " + bytesToHex(r2).toUpperCase());
# prints
  rmd: 00C5FAE41AB21FA56CFBAFA3AE7FB5784441D11CEC

重復SHA-256哈希兩次

我們現在需要對上面的結果執行兩次SHA-256哈希。

byte[] s2 = sha.digest(r2);
System.out.println("  sha: " + bytesToHex(s2).toUpperCase());
byte[] s3 = sha.digest(s2);
System.out.println("  sha: " + bytesToHex(s3).toUpperCase());

第二次散列結果的前4個字節用作地址校驗和。它附加到上面的RIPEMD160哈希。這是25字節的比特幣地址。

byte[] a1 = new byte[25];
for (int i = 0 ; i < r2.length ; i++) a1[i] = r2[i];
for (int i = 0 ; i < 5 ; i++) a1[20 + i] = s3[i];

使用Base58對地址進行編碼

我們現在使用bitcoinj庫中的Base58.encode()方法來獲得最終的比特幣地址。

System.out.println("  adr: " + Base58.encode(a1));
# prints
  adr: 1K3pg1JFPtW7NvKNA77YCVghZRq2s1LwVF

這是比特幣應在交易中發送到的地址。

這是一個如何在java中生成比特幣地址的演示文稿。我們生成一個ECDSA密鑰對,使用SHA256RIPEMD160哈希密鑰的公共部分。最后,我們通過執行SHA256兩次并選取前4個字節來計算校驗和,該字節附加到上面的RIPEMD160哈希。結果使用Base58編碼進行編碼。

覺得有點復雜,也可以看這個Java離線生成比特幣地址

建議你瀏覽我們匯智網的各種編程語言的區塊鏈教程和區塊鏈技術博客,更深入了解區塊鏈,比特幣,加密貨幣,以太坊,和智能合約。

  • java比特幣開發教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Java代碼中集成比特幣支持功能,例如創建地址、管理錢包、構造裸交易等,是Java工程師不可多得的比特幣開發學習課程。

  • php比特幣開發教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Php代碼中集成比特幣支持功能,例如創建地址、管理錢包、構造裸交易等,是Php工程師不可多得的比特幣開發學習課程。

  • php以太坊,主要是介紹使用php進行智能合約開發交互,進行賬號創建、交易、轉賬、代幣開發以及過濾器和交易等內容。

  • java以太坊開發教程,主要是針對java和android程序員進行區塊鏈以太坊開發的web3j詳解。

  • 以太坊入門教程,主要介紹智能合約與dapp應用開發,適合入門。

  • 以太坊開發進階教程,主要是介紹使用node.js、mongodb、區塊鏈、ipfs實現去中心化電商DApp實戰,適合進階。

  • python以太坊,主要是針對python工程師使用web3.py進行區塊鏈以太坊開發的詳解。

  • C#以太坊,主要講解如何使用C#開發基于.Net的以太坊應用,包括賬戶管理、狀態與交易、智能合約開發與交互、過濾器和交易等。

  • EOS入門教程,本課程幫助你快速入門EOS區塊鏈去中心化應用的開發,內容涵蓋EOS工具鏈、賬戶與錢包、發行代幣、智能合約開發與部署、使用代碼與智能合約交互等核心知識點,最后綜合運用各知識點完成一個便簽DApp的開發。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平潭县| 泰宁县| 皋兰县| 醴陵市| 舟曲县| 池州市| 喀什市| 临武县| 内丘县| 田阳县| 夏河县| 榆树市| 秦安县| 三门县| 沈丘县| 台北县| 和平区| 固安县| 宜兴市| 来安县| 虞城县| 青州市| 长葛市| 恩施市| 开原市| 泰顺县| 原平市| 禄劝| 萨迦县| 自治县| 雅江县| 永新县| 吉安市| 麟游县| 邵武市| 玛多县| 宁化县| 岑溪市| 大厂| 东乡| 敦化市|