Python 区块链 - 客户端类
客户端类使用内置的 Python RSA 算法生成 私钥 和 公钥。感兴趣的读者可以参考 本教程 了解 RSA 的实现。在对象初始化期间,我们创建私钥和公钥并将其值存储在实例变量中。
self._private_key = RSA.generate(1024, random) self._public_key = self._private_key.publickey()
请注意,您绝不能丢失私钥。为了保存记录,可以将生成的私钥复制到安全的外部存储器上,或者您可以简单地将其 ASCII 表示写在一张纸上。
生成的公钥将用作客户端的身份。为此,我们定义了一个名为 identity 的属性,它返回公钥的十六进制表示形式。
@property def identity(self): return binascii.hexlify(self._public_key.exportKey(format='DER')) .decode('ascii')
identity(身份)对于每个客户端都是唯一的,并且可以公开。任何人都可以使用此身份向您发送虚拟货币,并将其添加到您的钱包中。
Client(客户端)类的完整代码显示在此处 −
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')
测试客户端
现在,我们将编写代码来说明如何使用 Client 类 −
Dinesh = Client() print (Dinesh.identity)
上述代码创建 Client 的实例并将其分配给变量 Dinesh。我们通过调用其 identity 方法打印 Dinesh 的公钥。输出显示在此处 −
30819f300d06092a864886f70d010101050003818d0030818902818100b547fafceeb131e07 0166a6b23fec473cce22c3f55c35ce535b31d4c74754fecd820aa94c1166643a49ea5f49f72 3181ff943eb3fdc5b2cb2db12d21c06c880ccf493e14dd3e93f3a9e175325790004954c34d3 c7bc2ccc9f0eb5332014937f9e49bca9b7856d351a553d9812367dc8f2ac734992a4e6a6ff6 6f347bd411d07f0203010001
现在,我们让我们继续在下一章中创建交易。