本文将向大家介绍如何使用Python 3.9.4建立属于自己的区块链和加密货币。在构建自己的加密货币或区块链之前,您需要了解Python和区块链的基础知识。区块链或许看起来很复杂,但可以肯定的是其核心概念确实非常简单。
要求
确保您已安装最新版本的Python。
入门
创建一个新的Python文件,文件名app.py。首先,我们应该创建一个Block类。
我将参考dzone.com的代码:
class Block(object): def __init__(self): pass def compute_hash(self): pass
我们还需要创建Blockchain类蓝图:
class Blockchain(object): def __init__(self): pass def build_genesis(self): pass def build_block(self): pass @staticmethod def confirm_validity(block, previous_block): pass def get_data(self, sender, receiver, amount): pass @staticmethod def proof_of_work(last_proof): pass @property def latest_block(self): pass
积木类
现在,让我们看一下我们刚刚创建的这些类。块类将如下所示:
import hashlibimport timeclass Block(object): def __init__(self, index, proof_number, previous_hash, data, timestamp=None): self.index = index self.proof_number = proof_number self.previous_hash = previous_hash self.data = data self.timestamp = timestamp or time.time() @property def compute_hash(self): string_block = "{}{}{}{}{}".format(self.index, self.proof_number, self.previous_hash, self.data, self.timestamp) return hashlib.sha256(string_block.encode()).hexdigest()
Block类采用几个参数:index,proof_number,previous_hash,data和timestamp。
索引用于查看块在链中的哪个位置。
我认为,前者是不言而喻的。
数据是一个对象,它收集有关该区块的所有信息(id,金额,发送者,接收者等)。
时间戳是指生成块的时刻。
在def compute_hash()方法中,我们的哈希将使用hash方法创建。
链条类
单独的块没有任何价值,并且使用链来加密数据,因此很重要。让我们为Chain类创建构造函数:
class Blockchain(object): def __init__(self): self.chain = [] self.current_data = [] self.nodes = set() self.build_genesiss()
让我们看一下这些参数的作用。
该self.chain是一个变量,它存储所有的块。
该self.current_data是一个变量,它存储所有关于该块的信息。
这self.nodes是用于设置节点的示例方法。
所述self.build_genesis方法变量是创建第一块中的方法。
建立创世方法
此方法将用于创建初始块。因此,我们需要调用该build_block()方法。
def build_genesis(self): self.build_block(proof_number=0, previous_hash=0) def build_block(self, proof_number, previous_hash): block = Block( index=len(self.chain), proof_number=proof_number, previous_hash=previous_hash, data=self.current_data ) self.current_data = [] self.chain.append(block) return block
在此方法中,创建一个新Block对象并输入所需的参数:索引,证明,previous_hash和数据。然后,我们设置当前数据并将该块附加到链中。
确认有效性方法
创建加密货币/区块链的重要部分是检查区块是否有效。我们用一种新方法来做到这一点。
@staticmethod def confirm_validity(block, previous_block): if previous_block.index + 1 != block.index: return False elif previous_block.compute_hash() != block.previous_hash: return False elif block.timestamp & lt; = previous_block.timestamp: return False return True
让我们解释一下:此方法使用几个if语句来检查Block是否是它应该的块。它compute_hash()再次使用该方法。
获取数据方法
当然,您希望能够读取您的块和区块链的数据,这是通过以下get_data()方法完成的:
def get_data(self, sender, receiver, amount): self.current_data.append({ 'sender': sender, 'receiver': receiver, 'amount': amount }) return True
该方法非常简单,它采用三个参数并将它们添加到对象中。
工作证明
在这个项目中,我们将添加一个工作量证明算法以使挖掘成为可能。
让我们创建def block_mining方法:
def block_mining(self, details_miner): self.get_data( sender="0", receiver=details_miner, quantity=1, ) last_block = self.latest_block last_proof_number = last_block.proof_number proof_number = self.proof_of_work(last_proof_number) last_hash = last_block.compute_hash block = self.build_block(proof_number, last_hash) return vars(block)
定稿
为了结束我们的项目,我们将以下代码行添加到def latest_block方法中,
return self.chain[-1]
现在,我们将测试我们的项目:
bc = Blockchain()print("READY")print(bc.chain)#output:READY[<__main__.Block object at 0x00000241A23C5EE0>]
当您看到类似的结果时,您的区块链蓝图已成功构建。如果您想添加额外的功能,则可以这样做,请告诉我您所构建的内容!
完整代码示例:
import hashlibimport timeclass Block(object): def __init__(self, index, proof_number, previous_hash, data, timestamp=None): self.index = index self.proof_number = proof_number self.previous_hash = previous_hash self.data = data self.timestamp = timestamp or time.time() @property def compute_hash(self): string_block = "{}{}{}{}{}".format( self.index, self.proof_number, self.previous_hash, self.data, self.timestamp) return hashlib.sha256(string_block.encode()).hexdigest()class Blockchain(object): def __init__(self): self.chain = [] self.current_data = [] self.nodes = set() self.build_genesis() def build_genesis(self): self.build_block(proof_number=0, previous_hash=0) def build_block(self, proof_number, previous_hash): block = Block( index=len(self.chain), proof_number=proof_number, previous_hash=previous_hash, data=self.current_data ) self.current_data = [] self.chain.append(block) return block @staticmethod def confirm_validity(block, previous_block): if previous_block.index + 1 != block.index: return False elif previous_block.compute_hash() != block.previous_hash: return False elif block.timestamp >= previous_block.timestamp: return False return True def get_data(self, sender, receiver, amount): self.current_data.append({ 'sender': sender, 'receiver': receiver, 'amount': amount }) return True @staticmethod def proof_of_work(last_proof): pass @property def latest_block(self): return self.chain[-1] def block_mining(self, details_miner): self.get_data( sender="0", receiver=details_miner, quantity=1, ) last_block = self.latest_block last_proof_number = last_block.proof_number proof_number = self.proof_of_work(last_proof_number) last_hash = last_block.compute_hash block = self.build_block(proof_number, last_hash) return vars(block)bc = Blockchain()print("READY")print(bc.chain)
终于我们使用Python创建了自己的区块链。