首页 > 编程 > Python > 正文

Python实现类似比特币的加密货币区块链的创建与交易实例

2020-02-22 23:30:36
字体:
来源:转载
供稿:网友

虽然有些人认为区块链是一个早晚会出现问题的解决方案,但是毫无疑问,这个创新技术是一个计算机技术上的奇迹。那么,究竟什么是区块链呢?

区块链

以比特币(Bitcoin)或其它加密货币按时间顺序公开地记录交易的数字账本。

更通俗的说,它是一个公开的数据库,新的数据存储在被称之为区块(block)的容器中,并被添加到一个不可变的链(chain)中(因此被称为区块链(blockchain)),之前添加的数据也在该链中。对于比特币或其它加密货币来说,这些数据就是一组组交易,不过,也可以是其它任何类型的数据。

区块链技术带来了全新的、完全数字化的货币,如比特币和莱特币(Litecoin),它们并不由任何中心机构管理。这给那些认为当今的银行系统是骗局并将最终走向失败的人带来了自由。区块链也革命性地改变了分布式计算的技术形式,如以太坊(Ethereum)就引入了一种有趣的概念:智能合约(smart contract)。

在这篇文章中,我将用不到 50 行的 Python 2.x 代码实现一个简单的区块链,我把它叫做 SnakeCoin。

不到 50 行代码的区块链

我们首先将从定义我们的区块是什么开始。在区块链中,每个区块随同时间戳及可选的索引一同存储。在 SnakeCoin 中,我们会存储这两者。为了确保整个区块链的完整性,每个区块都会有一个自识别的哈希值。如在比特币中,每个区块的哈希是该块的索引、时间戳、数据和前一个区块的哈希值等数据的加密哈希值。这里提及的“数据”可以是任何你想要的数据。

import hashlib as hasherclass 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.hash_block()  def hash_block(self):  sha = hasher.sha256()  sha.update(str(self.index) +         str(self.timestamp) +         str(self.data) +         str(self.previous_hash))  return sha.hexdigest()import hashlib as hasher 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.hash_block()  def hash_block(self):  sha = hasher.sha256()  sha.update(str(self.index) +         str(self.timestamp) +         str(self.data) +         str(self.previous_hash))  return sha.hexdigest()

现在我们有了区块的结构了,不过我们需要创建的是一个区块链。我们需要把区块添加到一个实际的链中。如我们之前提到过的,每个区块都需要前一个区块的信息。但问题是,该区块链中的第一个区块在哪里?好吧,这个第一个区块,也称之为创世区块,是一个特别的区块。在很多情况下,它是手工添加的,或通过独特的逻辑添加的。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表