前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >以太坊密码学

以太坊密码学

作者头像
Tiny熊
发布2022-04-08 14:09:58
1.1K0
发布2022-04-08 14:09:58
举报
文章被收录于专栏:深入浅出区块链技术

本文作者:aisiji[1]

本文介绍在以太坊密码学是如何工作的?什么是公钥和私钥,以及如何使用它们

密钥和地址

以太坊有两种不同类型的账户:外部账户(EOAs)和合约。以太币的所有权是通过私钥,以太坊地址,和数字签名建立的。私钥是每个用户与以太坊交互的中心。事实上,账户地址直接来源于私钥:它唯一确定了一个以太坊地址,也叫账户。

私钥

私钥只是一个随机选择的数字。私钥的所有权和控制权是用户控制相应以太坊地址所有资产的根本,此外,用户还可以访问授权该地址的合约。私钥用于在交易中进行签名,以证明所有权。

必须确保私钥,如果将它透露给第三方就等于交出了以太币和合约的控制权。并且,必须要备份,以免意外丢失。如果私钥遗失,是无法恢复的,它所保护的资产也就永远丢失了。

从随机数生成私钥

生成密钥的第一步,也是最重要的一步,就是找到一个安全的熵或者随机数的源。创建以太坊私钥涉及到要从 1-2^{256} 中选择数字。以太坊软件使用底层操作系统的随机数生成器生成 256 位随机数。

私钥可以是任何非零的数字,可以大到只略小于 2^{256} 的非常大的数——一个非常大的 78 位的数,大约 1.158×10^{77}

2^{256} ——以太坊私钥空间的大小——是一个非常大的数字,十进制大约为 10^{77} ”——Andreas Antonopoulo,《Mastering Ethereum: Building Smart Contracts and DApps》的作者

注意,私钥生成是离线的;它与以太坊网络没有任何通信,也不需要。

不要自己编写代码来生成随机数或者用你的编程语言随机生成一个简单的随机数。

公钥

以太坊公钥是椭圆曲线上的一个点,一个满足椭圆曲线等式的(x,y)坐标。

它由两个从私钥生成的数字组成,并且只能单向生成,这意味着,如果你有一个私钥,就可以计算出公钥,但是你不能从公钥计算出私钥。

公钥是私钥通过椭圆曲线乘法得来,是不可逆的:K = k × G ,这里的 k 是私钥,G 是常数点(生成点),K 是公钥。

椭圆曲线乘法(×)与普通的乘法不同。它是一种单向函数:一个方向很容易计算出结果(乘法),而反方向则是不可能的(除法)。

椭圆曲线密码学

椭圆曲线密码学是非对称的,基于离散算法问题的公钥密码学,这种离散算法问题由椭圆曲线上的点的加法和乘法来表示。

以太坊使用与比特币相同的椭圆曲线,secp256k1——Andreas Antonopoulo,《Mastering Ethereum: Building Smart Contracts and DApps》的作者

-椭圆曲线-

以太坊使用一个特定的椭圆曲线和一组数学常数,标准定义为secp256k1secp256k1曲线由函数定义,该函数会产生一条椭圆曲线:y^2 = ( x^3 + 7) over ( \mathbb F p)

or:

mod p(素数)表明这条曲线在素数阶p的有限域上,p = 2²⁵⁶–2³²–2⁹–2⁸–2⁷–2⁶–2⁴–1,这是一个非常大的素数。

以太坊地址格式

以太坊地址是一个十六进制数,用公钥的 Keccak-256 哈希的后 20 字节表示。

生成公钥

我们可以用helpeth命令行工具来创建 ICAP 地址,用npm安装:

代码语言:javascript
复制
npm install -g helpeth

如果没有 npm,你可能就得按照这里的说明[2]来安装。

代码语言:javascript
复制
helpeth keyGenerate

输出:

代码语言:javascript
复制
Address: 0xe16c1623c1aa7d919cd2241d8b36d9e79c1be2a2
Address (checksum): 0xe16C1623c1AA7D919cd2241d8b36d9E79C1Be2A2
ICAP: XE56 QBY1 TCEL SB4U 7BTR QQRC IOUY 8UNS DK2
Public key: 0xaa931f5ee58735270821b3722866d8882d1948909532cf8ac2b3ef144ae8043363d1d3728b49f10c7cd78c38289c8012477473879f3b53169f2a677b7fbed0c7
Private key: 0x227dbb8586117d55284e26620bc76534dfbd2394be34cf4a09cb775d593b6f2b

现在我们将用给定的私钥来推出公钥,如下:

代码语言:javascript
复制
helpeth keyDetails \
  -p 0x227dbb8586117d55284e26620bc76534dfbd2394be34cf4a09cb775d593b6f2b

输出:

代码语言:javascript
复制
Address: 0xe16c1623c1aa7d919cd2241d8b36d9e79c1be2a2
Address (checksum): 0xe16C1623c1AA7D919cd2241d8b36d9E79C1Be2A2
ICAP: XE56 QBY1 TCEL SB4U 7BTR QQRC IOUY 8UNS DK2
Public key: 0xaa931f5ee58735270821b3722866d8882d1948909532cf8ac2b3ef144ae8043363d1d3728b49f10c7cd78c38289c8012477473879f3b53169f2a677b7fbed0c7

“互换客户端地址协议 (ICAP) 是一种以太坊地址编码,部分兼容国际银行帐号 (IBAN) 编码,为以太坊地址提供灵活、校验和且可互操作的编码。ICAP 地址可以对以太坊地址或在以太坊名称注册表中注册的通用名称进行编码。” — Andreas Antonopoulo,《Mastering Ethereum: Building Smart Contracts and DApps》的作者

原文:https://betterprogramming.pub/understanding-ethereum-cryptography-3ef7429eddce

参考资料

[1]

aisiji: https://learnblockchain.cn/people/3291

[2]

这里的说明: https://nodejs.org/

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-03-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 深入浅出区块链技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 密钥和地址
  • 私钥
    • 从随机数生成私钥
    • 公钥
    • 椭圆曲线密码学
      • 以太坊地址格式
      • 生成公钥
        • 参考资料
        相关产品与服务
        区块链
        云链聚未来,协同无边界。腾讯云区块链作为中国领先的区块链服务平台和技术提供商,致力于构建技术、数据、价值、产业互联互通的区块链基础设施,引领区块链底层技术及行业应用创新,助力传统产业转型升级,推动实体经济与数字经济深度融合。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档