欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

go语言实现简易比特币系统钱包的原理解析

程序员文章站 2022-07-04 23:53:01
钱包基础概念 广义上,钱包是一个应用程序,为用户提供交互界面。钱包控制用户访问权限、管理比特比地址及秘钥、跟踪余额、创建交易和签名交易 狭义上,即从程序员角度来看,“钱包”是指用于存储和管理用户秘...

钱包基础概念

  • 广义上,钱包是一个应用程序,为用户提供交互界面。钱包控制用户访问权限、管理比特比地址及秘钥、跟踪余额、创建交易和签名交易
  • 狭义上,即从程序员角度来看,“钱包”是指用于存储和管理用户秘钥的数据结构
  • 钱包是私钥的容器,一般是通过结构化文件或简单数据库来实现的
  • 钱包中并不包含比特币。比特币是被记录在比特币网络的区块链中,用户通过钱包中的密钥签名交易,从而控制网络中的比特币,在某种意义上,比特币钱包就是密钥链

钱包结构体

创建钱包

钱包集结构体

创建钱包集

创建钱包到钱包集

保存钱包到本地

读取钱包集里的钱包

列出所有钱包的地址

生成钱包地址

  • 随机选取32byte的数字作为私钥
  • 使用椭圆曲线加密算法(ecdsa-secp256k1)计算私钥对应的非压缩公钥
  • 计算公钥的sha-256哈希值
  • 取上一步结果,计算ripemd-160哈希值
  • 取上一步结果,前面加上版本号(比特币主网版本号“0x00”)
  • 取上一步结果,计算sha-256哈希值
  • 取上一步结果,计算sha-256哈希值
  • 取上一步结果的前4个字节(8位十六进制)
  • 把这4个字节加在第五步的结果后面,作为校验(这就是比特币地址的十六进制形态)
  • 用base58表示法变换一下地址(这就是常见的比特币地址形态)

结束

源码:https://gitee.com/xiaoshengdada/go_bitcoin/tree/master/v5

到此这篇关于go语言实现简易比特币系统钱包的原理解析的文章就介绍到这了,更多相关go实现比特币钱包内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!