区块链学习之公钥、私钥、签名和身份验证
区块链是一种去中心化的分布式账本技术,其中公钥和私钥是用于加密和解密数字资产的重要工具。
公钥是一个公开的密钥,私钥是一个私人的密钥。
公钥可以用于加密数据,而私钥可以用于解密数据。
签名是一种数字签名技术,它使用私钥对数据进行签名,以证明该数据来自特定人或实体。
身份验证是一种用于验证用户身份的技术,它使用公钥对用户进行身份验证。
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)