分享
golang[38]-区块链- 生成比特币地址
jonson_jackson · · 1636 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
生成比特币地址
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package main
import (
"crypto/sha256"
"golang.org/x/crypto/ripemd160"
"fmt"
"math/big"
"encoding/hex"
)
//base58编码
var b58Alphabet = []byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz")
func Base58Encode(input []byte) []byte{
var result []byte
x:= big.NewInt(0).SetBytes(input)
base := big.NewInt(int64(len(b58Alphabet)))
zero := big.NewInt(0)
mod := &big.Int{}
for x.Cmp(zero) != 0 {
x.DivMod(x,base,mod) // 对x取余数
result = append(result, b58Alphabet[mod.Int64()])
}
ReverseBytes(result)
for _,b:=range input{
if b ==0x00{
result = append([]byte{b58Alphabet[0]},result...)
}else{
break
}
}
return result
}
//字节数组的反转
func ReverseBytes(data []byte){
for i,j :=0,len(data) - 1;i<j;i,j = i+1,j - 1{
data[i],data[j] = data[j],data[i]
}
}
//产生比特币地址
func generateAddress(pubkey []byte) []byte{
//1、计算pubkeuhash
pubkeyHash256 :=sha256.Sum256(pubkey)
PIPEMD160Hasher := ripemd160.New()
_,err:= PIPEMD160Hasher.Write(pubkeyHash256[:])
if err!=nil{
fmt.Println("error")
}
publicRIPEMD160 := PIPEMD160Hasher.Sum(nil)
//2、计算checksum
versionPayload := append([]byte{0x00},publicRIPEMD160...)
firstSHA := sha256.Sum256(versionPayload)
secondSHA := sha256.Sum256(firstSHA[:])
//checksum 是前面的4个字节
checksum:=secondSHA[:4]
//3、base58编码
fullPayload := append(versionPayload,checksum...)
//返回地址
address:=Base58Encode(fullPayload)
return address
}
func main(){
//外部得到公钥
publickpey,_:=hex.DecodeString("D4A6C78C0B13DBD8A07AAB17C7D79ED9CB2523B63EDAC4E7CACE93C6B66CEDC7918EE0E174E8B2B61468D0E6CAA099710EF72094ACBD70BDAE3D8E42C617ACC6")
//fmt.Printf("%X",publickpey)
//打印这个地址
address:=generateAddress(publickpey)
fmt.Printf("%s",address)
}
参考资料
Building Blockchain in Go. Part 5: Addresses
本文链接: https://dreamerjonson.com/2018/12/07/golang-38-blockchain-generateAddress/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY 4.0 CN协议 许可协议。转载请注明出处!
image.png
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1636 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
生成比特币地址
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package main
import (
"crypto/sha256"
"golang.org/x/crypto/ripemd160"
"fmt"
"math/big"
"encoding/hex"
)
//base58编码
var b58Alphabet = []byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz")
func Base58Encode(input []byte) []byte{
var result []byte
x:= big.NewInt(0).SetBytes(input)
base := big.NewInt(int64(len(b58Alphabet)))
zero := big.NewInt(0)
mod := &big.Int{}
for x.Cmp(zero) != 0 {
x.DivMod(x,base,mod) // 对x取余数
result = append(result, b58Alphabet[mod.Int64()])
}
ReverseBytes(result)
for _,b:=range input{
if b ==0x00{
result = append([]byte{b58Alphabet[0]},result...)
}else{
break
}
}
return result
}
//字节数组的反转
func ReverseBytes(data []byte){
for i,j :=0,len(data) - 1;i<j;i,j = i+1,j - 1{
data[i],data[j] = data[j],data[i]
}
}
//产生比特币地址
func generateAddress(pubkey []byte) []byte{
//1、计算pubkeuhash
pubkeyHash256 :=sha256.Sum256(pubkey)
PIPEMD160Hasher := ripemd160.New()
_,err:= PIPEMD160Hasher.Write(pubkeyHash256[:])
if err!=nil{
fmt.Println("error")
}
publicRIPEMD160 := PIPEMD160Hasher.Sum(nil)
//2、计算checksum
versionPayload := append([]byte{0x00},publicRIPEMD160...)
firstSHA := sha256.Sum256(versionPayload)
secondSHA := sha256.Sum256(firstSHA[:])
//checksum 是前面的4个字节
checksum:=secondSHA[:4]
//3、base58编码
fullPayload := append(versionPayload,checksum...)
//返回地址
address:=Base58Encode(fullPayload)
return address
}
func main(){
//外部得到公钥
publickpey,_:=hex.DecodeString("D4A6C78C0B13DBD8A07AAB17C7D79ED9CB2523B63EDAC4E7CACE93C6B66CEDC7918EE0E174E8B2B61468D0E6CAA099710EF72094ACBD70BDAE3D8E42C617ACC6")
//fmt.Printf("%X",publickpey)
//打印这个地址
address:=generateAddress(publickpey)
fmt.Printf("%s",address)
}
参考资料
Building Blockchain in Go. Part 5: Addresses
本文链接: https://dreamerjonson.com/2018/12/07/golang-38-blockchain-generateAddress/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY 4.0 CN协议 许可协议。转载请注明出处!
image.png