持续创作,加速成长!这是我参与「掘金日新计划 · 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 :余数