区块链学习之公钥、私钥、签名和身份验证

区块链是一种去中心化的分布式账本技术,其中公钥和私钥是用于加密和解密数字资产的重要工具。

公钥是一个公开的密钥,私钥是一个私人的密钥。

公钥可以用于加密数据,而私钥可以用于解密数据。

签名是一种数字签名技术,它使用私钥对数据进行签名,以证明该数据来自特定人或实体。

身份验证是一种用于验证用户身份的技术,它使用公钥对用户进行身份验证。

 

import binascii
import Crypto
import Crypto.Random
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5


class Client:
   def __init__(self):
      random = Crypto.Random.new().read
      self._private_key = RSA.generate(1024, random)
      self._public_key = self._private_key.publickey()
      self._signer = PKCS1_v1_5.new(self._private_key)

   @property
   def identity(self):
      return binascii.hexlify(self._public_key.exportKey(format='DER')).decode('ascii')


Dinesh = Client()
print(Dinesh.identity)

 

 

 

posted @ 2023-11-16 11:16  aaronthon  阅读(69)  评论(0编辑  收藏  举报