go语言与区块链开发

524 阅读2分钟

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

代码:

func Sum256 (data []byte)[32]byte{
    var d digest
    d.Reset()
    d.Write(data)
    return d.checkSum()
}

对于任意不用的输入,Sum256都能返回一个32字节的数值(1字节==8位)

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

代码实现:

package main

import(
   "fmt"
   "math/big"
)


   //Base58编码基础数组
   var b58Alphabet =[]byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz")
   //字符串逆序
   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]
      }
   }
   //计算Base58编码
   func Base58Encode(input int64)[]byte{
      var result []byte
      x:=big.NewInt(input)
      //计算除数
      base :=big.NewInt(int64(len(b58Alphabet)))
      //获取big.Int类型得0
      zero :=big.NewInt(0)
      //储存余数
      mod :=&big.Int{}
      //只要被除数不为0,就继续计算
      for x.Cmp(zero)!=0{
      x.DivMod(x,base,mod)
      //取出编码,储存到result中
      result =append(result,b58Alphabet[mod.Int64()])
   }
      //结果逆序
      ReverseBytes(result)
      return result
   }
 func main(){
   result :=Base58Encode(258)
   fmt.Println(string(result))
 }

代码中使用了big.Int类型,该类型可以支持更大得整数,请内部方法DivMod可以更方柏地让我们获得除法得商和余数。

x.DivMod(x,base,mod)

x:被除数           y:除数      mod :余数