区块链(BlockChain)中私钥、公钥和钱包地址三者关系

时间:2024-04-11 11:09:37

入门区块链,听得最多的3个术语就是【私钥】、【公钥】和【钱包地址】,如果不加以区分,很容易搞混淆,直接影响今后又好又快地学习。今天就学习三者之间的关系。

学习之前,我必须强调!私钥、公钥中的“钥”,读音是yuè!读音是yuè!读音是yuè!不是yào !不是yào !不是yào !

下面开始。

1.私钥

私钥,即私有**,只有你自己可以知道,公开后你的币就没了。本质是一串256bit的数字(也就是由256个“0”和“1”组成)。

2.公钥

公钥,即公开**,可对全节点公开,公开后无任何风险。

3.钱包地址

钱包地址,可理解为Cyberspace中的银行卡账号,可对全节点公开,公开后无任何风险,本质是一串字符串。

4.三者关系

4.1 私钥-公钥关系

  • 公钥和私钥成对出现
  • 公开的**叫公钥,只有自己知道的叫私钥
  • 用公钥加密的数据只有对应的私钥可以解密
  • 用私钥加密的数据只有对应的公钥可以解密
  • 如果可以用公钥解密,则必然是对应的私钥加的密
  • 如果可以用私钥解密,则必然是对应的公钥加的密

4.2 三者相互生成关系

为什么说私钥只能自己知道,而公钥和钱包地址却可以随意公开?这跟三者的生成关系直接相关。

区块链(BlockChain)中私钥、公钥和钱包地址三者关系
从上图可以看出,私钥可以生成公钥和钱包地址,而公钥却不能生成私钥,同时,钱包地址不能生成公钥。具体看下图:

区块链(BlockChain)中私钥、公钥和钱包地址三者关系

  1. 首先使用随机数发生器生成一个『私钥』。一般来说这是一个256bits的数,拥有了这串数字就可以对相应『钱包地址』中的比特币进行操作,所以必须被安全地保存起来。

  2. 『私钥』经过SECP256K1算法处理生成了『公钥』。SECP256K1是一种椭圆曲线算法,通过一个已知『私钥』时可以算得『公钥』,而『公钥』已知时却无法反向计算出『私钥』。这是保障比特币安全的算法基础。

  3. 同SHA256一样,RIPEMD160也是一种Hash算法,由『公钥』可以计算得到『公钥哈希』,而反过来是行不通的。

  4. 将一个字节的地址版本号连接到『公钥哈希』头部(对于比特币网络的pubkey地址,这一字节为“0”),然后对其进行两次SHA256运算,将结果的前4字节作为『公钥哈希』的校验值,连接在其尾部。

  5. 将上一步结果使用BASE58进行编码(比特币定制版本),就得到了『钱包地址』。

    比如, 1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa

至此,私钥、公钥和钱包地址的关系已经较为明朗。