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

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

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

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

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

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

 

复制代码
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 @   aaronthon  阅读(265)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
历史上的今天:
2020-11-16 ERROR: Error loading ASGI app. Could not import module "main".
2018-11-16 python处理u开头的字符串
2018-11-16 python中unicode 和 str相互转化
点击右上角即可分享
微信分享提示