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