以太坊系地址衍生算法分层确定性生成逻辑

server/2024/11/14 5:55:14/

文章目录

  • 一、前言
  • 二、私钥生成及私钥提取
    • 2.1 golang如何使用衍生算法生成私钥,然后为用户生成地址
      • 2.1.1 实现步骤
      • 2.1.2 golang代码示例
      • 2.1.3 代码说明
    • 2.2 地址交易时,如何提取地址私钥
      • 2.2.1 私钥恢复说明
      • 2.2.2 golang代码通过助记词恢复私钥示例
      • 2.2.3 代码说明
  • 三、将地址衍生算法应用到中心化钱包中
    • 3.1 将地址衍生算法应用到中心化钱包中
      • 3.1.1 架构设计
        • 3.1.1.1 安全的地址生成方式
        • 3.1.1.2 安全转账流程设计
        • 3.1.1.3 大规模用户管理
        • 3.1.1.4 安全监控和风控设计
      • 3.1.2 使用公钥验证地址身份信息(是否为钱包系统生成)
        • 3.1.2.1 为什么要存储公钥信息
        • 3.1.2.2 golang 通过公钥校验地址是否伪造
    • 3.2 使用主私钥恢复子私钥
      • 3.2.1 主私钥的作用
      • 3.2.1 主私钥恢复子私钥的具体流程
      • 3.2.1 golang使用主私钥恢复子私钥
  • 四、秘钥路径及BIP44
  • 五、 为什么:每个account下的address_index不要超过20个?
    • 5.1 建议address_index不要超过20个的原因
    • 5.2 什么是自动扫描和恢复地址?
      • 5.2.1 钱包的扫描和恢复流程
      • 5.2.2 为什么“自动扫描和恢复”重要?
      • 5.2.3 如果每个account下的address_index生成了非常多,会影响钱包使用吗?
  • 六、根据每个address_index根据建议20个,如果我需要上千万个地址,那么应该如何实现?
    • 6.1 实现思路
    • 6.2 golang实现批量生成和管理地址
    • 6.3 除了增加更多的account,还会有其它的解决方式吗?
      • 6.3.1 增加地址的扫描深度
      • 6.3.2 分区索引(Sharded Indexing)
      • 6.3.3 分区索引 代码如何实现
      • 6.3.4 根据address_index 派生地址和 根据 userID 派生地址 的区别是什么?

一、前言

在中心化钱包中,区块链地址的私钥一般通过衍生算法生成,而不是直接通过简单的随机生成。这是因为衍生算法生成的私钥可以通过种子或主密钥管理,更适合多账户管理和增强安全性。

1.1 衍生算法生成的私钥

常见的中心化钱包多采用HD(分层确定性)钱包标准,比如 BIP32BIP39BIP44 等。通过这些标准:

主私钥或种子:钱包会生成一个主私钥或种子,这个种子通过密码学算法生成,然后可以衍生出一系列私钥。
私钥衍生路径:使用类似m/44’/60’/0’/0/0的路径规则,可以为每个用户、每条链或每个账户生成独立的私钥。
优点只需备份一个种子或主密钥,即可恢复所有私钥,大大简化了备份过程,提高了安全性。

1.2 随机生成的私钥

直接随机生成私钥的方式在一些单账户钱包中可能会使用,但在中心化钱包中很少见。这种方式管理多个账户的私钥较为繁琐,不适合规模化管理。

总结


http://www.ppmy.cn/server/141776.html

相关文章

k8s拓扑域 :topologyKey

主要用于定义Pod亲和性或反亲和性规则中的拓扑域,从而控制Pod在集群中的调度。 参数描述:仅支持在工作负载亲和/工作负载反亲和调度策略中使用。先圈定拓扑域(topologyKey)指定的范围,然后再选择策略定义的内容。 to…

详解二叉树(上)---堆

目录 一、树 1.2 树的相关术语 1.3 树的表示方法 二、二叉树 2.1 概念与结构 2.2 二叉树的特殊形式 2.3 二叉树的性质 2.4 二叉树的存储结构 1.顺序结构 2.链式结构 2.5 实现顺序结构二叉树(堆) 1.堆的概念 2. 堆的性质 3.堆的实现 三、全…

MySQL Workbench导入数据比mysql命令行慢

1.数据量 包含2812979条数据的csv文件 2.myql命令行用LOAD DATA INFILE命令导入 耗时1分钟13秒 3.用MySQL Workbench导入 从第一天晚上22点到次日下午16点才导入了45万条数据 4.原因 MySQL Workbench导入csv数据是使用自带的python和一系列的python代码,而mys…

【大数据学习 | HBASE】hbase shell基础实操

1. 查看hbase状态 # 进入hbase 命令行 hbase shell status 我这里没启用高可用hbase 1 active master, 0 backup masters, 2 servers, 1 dead, 1.0000 average load Took 5.2635 seconds 2. 查看版本号 version hbase:002:0> version 2.4.11, r7e672a0da0586e6b7449…

高效共享出行:基于SpringBoot的汽车管理系统

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及,互联网成为人们查找信息的重要场所,二十一世纪是信息的时代,所以信息的管理显得特别重要。因此,使用计算机来管理共享汽车管理系统的相关信息成为必然。开发…

Kotlin设计模式:Java中的桥接模式与中介模式

Kotlin设计模式:Java中的桥接模式与中介模式 abstract class AbsCls {abstract fun setFlag(f: Int)abstract fun getFlag(): Int }class ACls : AbsCls {private var flag 0constructor() {println("ACls constructor")}override fun setFlag(f: Int) {println(&qu…

开源TTS语音克隆神器GPT-SoVITS_V2版本地整合包部署与远程使用生成音频

文章目录 前言1.GPT-SoVITS V2下载2.本地运行GPT-SoVITS V23.简单使用演示4.安装内网穿透工具4.1 创建远程连接公网地址 5. 固定远程访问公网地址 前言 本文主要介绍如何在Windows系统电脑使用整合包一键部署开源TTS语音克隆神器GPT-SoVITS,并结合cpolar内网穿透工…

【后端速成Vue】模拟实现翻译功能

前言: 本期将会介绍 Vue 中的 watch 侦听器,它语法是怎么样的呢?具有怎样的功能呢?最后用模拟实现百度翻译来更进一步练习 watch 侦听器 篮球哥找工作专属IT岗位内部推荐: 专属内推链接:内推通道 1、认识翻…