Python Blockchain 简明教程

Python Blockchain - Client Class

Client 类使用内置 Python RSA 算法生成 privatepublic 密钥。有兴趣的读者可以参考 this tutorial 以了解 RSA 的实现。在对象初始化期间,我们创建私钥和公钥,并将它们的值存储在实例变量中。

self._private_key = RSA.generate(1024, random)
self._public_key = self._private_key.publickey()

请注意,您绝不能丢失您的私钥。为了记录,生成的私钥可以复制到安全的外置存储设备上,或者您也可以简单地在纸上写下它的 ASCII 表示。

生成的 public 密钥将用作客户的身份。为此,我们定义一个名为 identity 的属性,它返回公钥的 HEX 表示。

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

identity 对每个客户都是唯一的,并且可以公开。任何人都可以使用此 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')

Testing Client

现在,我们将编写代码来说明如何使用 Client 类 -

Dinesh = Client()
print (Dinesh.identity)

上述代码创建了一个 Client 实例,并将其赋值给变量 Dinesh 。我们通过调用其 identity 方法来打印 Dinesh 的公钥。输出如下 −

30819f300d06092a864886f70d010101050003818d0030818902818100b547fafceeb131e07
0166a6b23fec473cce22c3f55c35ce535b31d4c74754fecd820aa94c1166643a49ea5f49f72
3181ff943eb3fdc5b2cb2db12d21c06c880ccf493e14dd3e93f3a9e175325790004954c34d3
c7bc2ccc9f0eb5332014937f9e49bca9b7856d351a553d9812367dc8f2ac734992a4e6a6ff6
6f347bd411d07f0203010001

现在,让我们继续在下一章中创建一笔交易。