赞
踩
持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第4天,点击查看活动详情
GO语言之所以可以被称为区块链编程第一语言,主要是因为GO语言对加密函数的支持非常友好。
GO语言为开发者直接提供了MD5、sha1、sha256、sha512四个官方包,其中sha1实现了 SHA1算法,sha256实现了SHA-224和SHA-256算法等。比特币系统使用的是SHA-256算法。
### 使用sha256演示hash算法的使用
在sha256包中,直接使用Sum256函数就可以得到32字节的hash值
代码:
go func Sum256 (data []byte)[32]byte{ var d digest d.Reset() d.Write(data) return d.checkSum() }
对于任意不用的输入,Sum256都能返回一个32字节的数值(1字节==8位)
```go package main import( "crypto/sha256" "fmt" )
- func main(){
- //计算hash值
- hash :=sha256.Sum256([]byte("hello! blackchain"))
- fmt.Printf("%x/n",hash)
-
- //hash值结果
- 4cd25d8f434f97590e626b05b3760540c31279ac8fb4656ba698087ebd27a9fc
- }
```
比特币钱包地址是使用Base58编码生成的。 Base58编码的计算方式是辗转相除法。(求最大公约数) 比如 一个数值位258 1、使用258/58 得 4·····26
2、与Base58编码表对比,得到对应字母T
3、使用4/58 得到0·····4 对应字母是5 所以 258对应得编码是5T
代码实现:
```go package main
import( "fmt" "math/big" )
//Base58编码基础数组 var b58Alphabet =[]byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz") //字符串逆序 func ReverseBytes(data []byte){ for i,j :=0,len(data)-1;i
x.DivMod(x,base,mod)
x:被除数 y:除数 mod :余数
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。