用不到 50 行的 Python 代码构建最小的区块链

译文:CSDN - 黑色巧克力

geek.csdn.net/news/detail/228355

尽管一些人认为区块链是一个等待问题的解决方案,但毫无疑问,这种新技术是计算机的奇迹。但是,区块链到底是什么呢?

区块链

它是比特币或其他加密货币进行交易的数字账本,账本按时间顺序记录并对外公开。

在更一般的术语中,它是一个公共数据库,新数据存储在一个名为块的容器中,并被添加到一个不可变链(后来的区块链)中添加了过去的数据。在比特币和其他加密货币的情况下,这些数据是一组交易记录。当然,数据可以是任何类型的。

区块链技术已经催生了新的、完全数字化的货币,如比特币和莱特币,这些货币并不是由中央政府发行或管理的。因此为那些认为今天的银行系统是骗局或终将失败的人带来了新的自由。区块链所包含的以太坊技术对分布式计算进行了变革创新,它引入了一些有趣的概念,比如智能合约。

在本文中,我将用不到50行的Python2代码来做一个简单的区块链。我称它为SnakeCoin。

首先将定义块将是什么样子。在区块链中,每个块都存储一个时间戳和一个索引。在SnakeCoin中,需要把两者都存储起来。为了确保整个区块链的完整性,每个块都有一个自动识别散列。与比特币一样,每个块的散列将是块索引、时间戳、数据和前块哈希的加密哈希。数据可以是你想要的任何东西。

importhashlibashasher

classBlock:

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()

defhash_block(self):

sha=hasher.sha256()

sha.update(str(self.index)+

str(self.timestamp)+

str(self.data)+

str(self.previous_hash))

returnsha.hexdigest()

这一步后有块结构,但现在是创建区块链,所以需要向实际的链中添加块。如前所述,每个块都需要上一个块的信息。但是按照这个说法就有一个问题,区块链的第一个区块是如何到达那里的呢?不得不说,第一个块,或者说是起源块,它是一个特殊的块。在很多情况下,它是手动添加的,或者有独特的逻辑允许添加。

下面将创建一个函数简单地返回一个起源块以便产生第一个区块。这个块是索引0,它具有任意的数据值和“前一个哈希”参数中的任意值。

importdatetimeasdate

defcreate_genesis_block():

# Manually construct a block with

# index zero and arbitrary previous hash

现在已经创建好了起源块,接下来需要一个函数,以便在区块链中生成后续的块。这个函数将把链中的前一个块作为参数,创建要生成的块的数据,并使用适当的数据返回新块。当新的块哈希信息来自前面的块时,区块链的完整性会随着每个新块而增加。如果不这样做,外部组织就更容易“改变过去”,用全新的方式取代已有的链条。这一系列的散列可以作为加密的证据,有助于确保一旦将块添加到区块链,它就不能被替换或删除。

defnext_block(last_block):

this_index=last_block.index+1

this_data="Hey! I'm block "+str(this_index)

this_hash=last_block.hash

returnBlock(this_index,this_timestamp,this_data,this_hash)

大部分的工作已经完成,现在可以创建区块链了。在这次的示例中,区块链本身是一个简单的Python列表。列表的第一个元素是起源块。当然,还需要添加后续的块,因为SnakeCoin是最小的区块链,这里只添加20个新的块。可以用for循环来生成新块。

# Create the blockchain and add the genesis block

blockchain=[create_genesis_block()]

previous_block=blockchain[]

# How many blocks should we add to the chain

# after the genesis block

num_of_blocks_to_add=20

# Add blocks to the chain

foriinrange(,num_of_blocks_to_add):

block_to_add=next_block(previous_block)

blockchain.append(block_to_add)

previous_block=block_to_add

# Tell everyone about it!

print"Block #{} has been added to the blockchain!".format(block_to_add.index)

print"Hash: {}\n".format(block_to_add.hash)

下面来测试一下目前产生的区块链。

本文来自企鹅号 - 程序员的那些事媒体

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏程序员互动联盟

如何深入学习C语言?

疑惑一 遇见编译错误了咋办? 经常见有小伙伴,呼呼的把一大段的编译错误呈现在群里,然后问这是啥原因,其实解决编译的办法还是挺多,现在重点说下编译错误是怎么出来的...

3015
来自专栏技术专栏

2.3 添加工作量证明方法

回顾一下工作量证明的原理,对交易信息进行hash,并引入随机字符串来得到hash结果,对hash结果进行难度限制,限制必须以n个0开头。这样节点需要消耗算力不断...

702
来自专栏阮一峰的网络日志

1979年的电子打字机

上周五,《大西洋》月刊的记者James Fallows,在Blog上回忆28年前(1982年)的一篇旧文。 那个时候,他刚入行不久,每周有大量的写稿任务,天天都...

2674
来自专栏汇智网教程

以太坊中的iban概念解析

2115
来自专栏企鹅号快讯

写最少的代码,避免给自己找麻烦

软件开发的一个最基本的事实是:我们必须要写代码,但对于这样的一个事实的最大一个误解是:我们的工作就是写代码。作为软件程序员的最初几年,我一直被这样的思想所迷惑,...

1906
来自专栏coding for love

ES6常用新特性学习

说起ES6,想必大家都不陌生了。ES6 的第一个版本,在 2015 年 6 月发布,正式名称是《ECMAScript 2015 标准》(简称 ES2015)。这...

553
来自专栏即时通讯技术

微信手机端的本地数据全文检索优化之路

基于本地数据的全文搜索(Full-Text-Search,FTS)在移动应用上扮演着重要的角色。与基于服务端提供的搜索服务不同,移动端受硬件条件限制,尤其在数据...

732
来自专栏web前端教室

【不理解】学习前端开发的路上,你是自己绊倒了自己吗?

讲课对于我来讲,是以一种半双向的形式,在和学生们做实时的交流。为什么说是半双向呢?

873
来自专栏Hongten

python开发_自己开发的一个小游戏

=================================================

852
来自专栏木宛城主

敏捷团队的规范与准则

1.序言 打造一个金诚所至的敏捷团队,需要大家自发的来遵守以及完善相应的规范。大家在自我约束的前提下,彼此之间互相影响,由下而上推动团队的建设。所以规矩、准则...

2069

扫码关注云+社区