钱包基础概念

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

钱包结构体

创建钱包

钱包集结构体

创建钱包集

创建钱包到钱包集

保存钱包到本地

读取钱包集里的钱包

列出所有钱包的地址

生成钱包地址

  • 随机选取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实现比特币钱包内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!