python实现简单区块链结构


Posted in Python onApril 25, 2021

区块链

比特币从诞生到现在已经10年了,最近接触到了区块链相关的技术,为了揭开其背后的神秘面纱,我就从头开始构建一个简单的区块链。

从技术上来看:区块是一种记录交易的数据结构,反映了一笔交易的资金流向。系统中已经达成的交易的区块连接在一起形成了一条主链,所有参与计算的节点都记录了主链或主链的一部分。

python实现简单区块链结构

一、比特币内部结构

比特币内部结构有四部分:

  1. previous hash: 上一个区块的hash
  2. data:交易数据
  3. time stamp:区块生成的时间戳
  4. nonce:挖矿计算次数

二、实现的比特币结构

  1. index :当前区块索引
  2. timestamp :该区块创建时的时间戳
  3. data :交易信息
  4. previous hash: 前一个区块的hash
  5. hash: 当前区块的hash
  6. nonce : 挖矿计算次数

注意:当前实现了一个简单的区块链结构,并不完整。

三、代码实现

1.定义区块的结构

代码如下:

"""
区块设计
"""
import time
import hashlib

class Block:
    # 初始化一个区块
    def __init__(self,previous_hash,data):
        self.index = 0
        self.nonce = ''
        self.previous_hash = previous_hash
        self.time_stamp = time.time()
        self.data = data
        self.hash = self.get_hash()
    # 获取区块的hash
    def get_hash(self):
        msg = hashlib.sha256()
        msg.update(str(self.previous_hash).encode('utf-8'))
        msg.update(str(self.data).encode('utf-8'))
        msg.update(str(self.time_stamp).encode('utf-8'))
        msg.update(str(self.index).encode('utf-8'))
        return msg.hexdigest()
    # 修改区块的hash值
    def set_hash(self,hash):
        self.hash = hash

2.创世区块构造

创世区块:没有前一个区块,这里的previous_hashdata是自己写死的。

# 生成创世区块,这是第一个区块,没有前一个区块
def creat_genesis_block():
    block = Block(previous_hash= '0000',data='Genesis block')
    nonce,digest = mime(block=block)
    block.nonce = nonce
    block.set_hash(digest)
    return block

这里的mime()函数是后面的挖矿函数.

3.挖矿函数定义

代码如下:

def mime(block):
    """
    挖矿函数——更新区块结构,加入nonce值
        block:挖矿区块
    """
    i = 0
    prefix = '0000'
    while True:
        nonce = str(i)
        msg = hashlib.sha256()
        msg.update(str(block.previous_hash).encode('utf-8'))
        msg.update(str(block.data).encode('utf-8'))
        msg.update(str(block.time_stamp).encode('utf-8'))
        msg.update(str(block.index).encode('utf-8'))
        msg.update(nonce.encode('utf-8'))
        digest = msg.hexdigest()
        if digest.startswith(prefix):
            return nonce,digest
        i+=1

4.定义区块链结构

代码如下:

"""
区块链设计
"""
from Block import *
# 区块链
class BlockChain:
    def __init__(self):
        self.blocks = [creat_genesis_block()]
    # 添加区块到区块链上
    def add_block(self,data):
        pre_block = self.blocks[len(self.blocks)-1]
        new_block = Block(pre_block.hash,data)
        new_block.index = len(self.blocks)
        nonce,digest = mime(block=new_block)
        new_block.nonce = nonce
        new_block.set_hash(digest)
        self.blocks.append(new_block)
        return new_block

在添加新区块到区块链时,先挖矿在将新区块加入区块链。

四、代码运行

测试代码:

from BlockChain import *
# 创建一个区块链
bc = BlockChain()
# 添加区块
bc.add_block(data='second block')
bc.add_block(data='third block')
bc.add_block(data='fourth block')
for bl in bc.blocks:
    print("Index:{}".format(bl.index))
    print("Nonce:{}".format(bl.nonce))
    print("Hash:{}".format(bl.hash))
    print("Pre_Hash:{}".format(bl.previous_hash))
    print("Time:{}".format(bl.time_stamp))
    print("Data:{}".format(bl.data))
    print('\n')

运行结果:

python实现简单区块链结构

这里添加了4个区块(包括创世区块),处了创世区块,每个区块的pre_hash都与前一个区块的hash值相等,这代表区块没有被篡改,数据有效。

到此这篇关于python实现简单区块链结构的文章就介绍到这了,更多相关python区块链结构内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
使用python实现strcmp函数功能示例
Mar 25 Python
Python实现线程池代码分享
Jun 21 Python
Flask的图形化管理界面搭建框架Flask-Admin的使用教程
Jun 13 Python
Python实现动态图解析、合成与倒放
Jan 18 Python
对python中的 os.mkdir和os.mkdirs详解
Oct 16 Python
jupyter notebook参数化运行python方式
Apr 10 Python
在Sublime Editor中配置Python环境的详细教程
May 03 Python
Nginx+Uwsgi+Django 项目部署到服务器的思路详解
May 08 Python
PyTorch安装与基本使用详解
Aug 31 Python
python/golang 删除链表中的元素
Sep 14 Python
学会迭代器设计模式,帮你大幅提升python性能
Jan 03 Python
python内置模块之上下文管理contextlib
Jun 14 Python
python实现图片九宫格分割的示例
详解python中[-1]、[:-1]、[::-1]、[n::-1]使用方法
Apr 25 #Python
浅谈Python项目的服务器部署
Apr 25 #Python
Python Socket编程详解
Apr 25 #Python
Python Django 后台管理之后台模型属性详解
如何用python反转图片,视频
python基于tkinter制作m3u8视频下载工具
You might like
拼音码表的生成
2006/10/09 PHP
如何使用PHP计算上一个月的今天
2013/05/23 PHP
PHP中COOKIES使用示例
2015/07/26 PHP
PHP扩展Memcache分布式部署方案
2015/12/06 PHP
PHP对象实例化单例方法
2017/01/19 PHP
Yii2语言国际化自动配置详解
2018/08/22 PHP
PHP时间处理类操作示例
2018/09/05 PHP
JavaScript 组件之旅(三):用 Ant 构建组件
2009/10/28 Javascript
js 获取Listbox选择的值的代码
2010/04/15 Javascript
五个jQuery图片画廊插件 推荐
2011/05/12 Javascript
JavaScript实现多维数组的方法
2013/11/20 Javascript
常规表格多表头查询示例
2014/02/21 Javascript
微信小程序 wx:key详细介绍
2016/10/28 Javascript
nodejs 实现钉钉ISV接入的加密解密方法
2017/01/16 NodeJs
Vue-Router实现页面正在加载特效方法示例
2017/02/12 Javascript
jQuery操作attr、prop、val()/text()/html()、class属性
2019/05/23 jQuery
使用axios请求时,发送formData请求的示例
2019/10/29 Javascript
JS this关键字在ajax中使用出现问题解决方案
2020/07/17 Javascript
vue 根据选择的月份动态展示日期对应的星期几
2021/02/06 Vue.js
[01:25]DOTA2超级联赛专访iG 将调整状态找回自己
2013/06/05 DOTA
python图的深度优先和广度优先算法实例分析
2019/10/26 Python
详解Python中的format格式化函数的使用方法
2019/11/20 Python
Python绘制二维曲线的日常应用详解
2019/12/04 Python
Python chardet库识别编码原理解析
2020/02/18 Python
CSS3点击按钮实现背景渐变动画效果
2016/10/19 HTML / CSS
商务日语专业毕业生求职信
2013/10/26 职场文书
医科大学生毕业的自我评价分享
2013/11/12 职场文书
简历中自我评价怎么写
2014/02/12 职场文书
校园公益广告语
2014/03/13 职场文书
知识改变命运演讲稿
2014/05/21 职场文书
电子商务求职信
2014/06/15 职场文书
处级领导干部四风问题自我剖析材料
2014/09/29 职场文书
语文教师个人工作总结
2015/02/06 职场文书
政审证明材料
2015/06/19 职场文书
体育教师教学随笔
2015/08/15 职场文书
2016年优秀少先队辅导员事迹材料
2016/02/26 职场文书