区块链基石:区块头、体与数据结构详解

文章正文
发布时间:2025-08-22 20:41

好的,我可以帮你实现一个简单的10个区块的区块链。首先,我们需要定义一个区块的数据结构。一个基本的区块包含以下信息: - 区块索引(index):该区块在整个区块链中的位置。 - 时间戳(timestamp):该区块创建的时间。 - 数据(data):该区块存储的数据。 - 上一个区块的哈希值(previous_hash):该区块前一个区块的哈希值。 - 当前区块的哈希值(hash):该区块的哈希值,用于验证该区块的完整性。 接下来,我们可以定义一个区块链的类。该类包含以下方法: - add_block:向区块链中添加一个新的区块。 - calculate_hash:计算区块的哈希值。 - get_latest_block:获取区块链中最后一个区块的引用。 下面是实现一个简单的10个区块的区块链的Python代码示例: ```python import hashlib import datetime as date class Block: def __init__(self, index, timestamp, data, previous_hash): self.index = index self.timestamp = timestamp self.data = data self.previous_hash = previous_hash self.hash = self.calculate_hash() def calculate_hash(self): sha = hashlib.sha256() sha.update(str(self.index).encode('utf-8') + str(self.timestamp).encode('utf-8') + str(self.data).encode('utf-8') + str(self.previous_hash).encode('utf-8')) return sha.hexdigest() class Blockchain: def __init__(self): self.chain = [self.create_genesis_block()] def create_genesis_block(self): return Block(0, date.datetime.now(), "Genesis Block", "0") def add_block(self, data): index = len(self.chain) timestamp = date.datetime.now() previous_hash = self.get_latest_block().hash block = Block(index, timestamp, data, previous_hash) self.chain.append(block) def get_latest_block(self): return self.chain[-1] blockchain = Blockchain() for i in range(1, 11): blockchain.add_block("Block " + str(i)) for block in blockchain.chain: print("Block " + str(block.index)) print("Data: " + block.data) print("Timestamp: " + str(block.timestamp)) print("Previous Hash: " + block.previous_hash) print("Hash: " + block.hash) print("\n") ``` 运行上面的代码,你会得到一个包含10个区块的简单的区块链。每个区块包含了它的索引、数据、时间戳、前一个区块的哈希值和它自己的哈希值。

首页
评论
分享
Top