我有一个函数,它生成一个block,其中包含一些数据:def new_block(self, proof, previous_hash=None):
...
block = {
'message': 'New Block Forged',
'index': len(self.chain) + 1,
'transactions': self.current_transactions,
'proof': proof,
'previous_hash': previous_hash, or self.hash_block(self.chain[-1]),
'timestamp': response.tx_time or time(),
}
self.chain是块所在的块的列表。previous_hash(前一个块的散列)被传递给函数,并创建一个时间戳。不要太担心实际数据的细节(好吧,有些地方可能有问题,但它与hash()函数有关,而不是数据的情况)
接下来,我散列块,并将其添加到块中:
block['hash'] = self.hash_block(block)
hash_block函数如下所示:
^{pr2}$
此函数创建一个与行中的下一个块完全不同的哈希(链上附加到前面块的最后一个块的哈希与前面块的previous_hash不匹配)。但是,它们使用相同的功能:
这条线:
'previous_hash': previous_hash or self.hash_block(self.chain[-1])
这条线:
block['hash'] = self.hash_block(block)
是重要的行(和hash_block)函数。创建一个块,对其进行哈希处理并附加哈希值,然后创建另一个块并对前一个块进行哈希处理,但它与创建该块时为该块创建的哈希值不匹配。在
而且,我一开始hashlib.sha256,当我注意到这个问题时,我决定看看它是否是哈希函数,所以我切换到了stock哈希,但我仍然有问题-最终我希望这个函数能在hashlib上工作,但我想如果我能先让它与hash一起工作,我将为hashlib解决问题在