持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第4天,点击查看活动详情
go语言与区块链开发GO语言之所以可以被称为区块链编程第一语言,主要是因为GO语言对加密函数的支持非常友好。
go与hash函数
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() }
```go package main import( "crypto/sha256" "fmt" )
func main(){
//计算hash值
hash :=sha256.Sum256([]byte("hello! blackchain"))
fmt.Printf("%x/n",hash)
//hash值结果
4cd25d8f434f97590e626b05b3760540c31279ac8fb4656ba698087ebd27a9fc
}
```
GO语言和Base58编码
比特币钱包地址是使用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 :余数