python区块_python区块及区块链的开发详解
接着上一篇交易记录整合交易类,这里描述区块的开发。
首先我们要明白一个区块,需要的内容,包括交易记录集合,时间戳,哈希,上一个区块的哈希。明白了这个,下面就容易代码开发了。
import datetime
import hashlib
from Message import DaDaMessage, InvalidMessage
from Transaction import Transaction
class Block:
#不定参数,*args,区块集合
def __init__(self, *args):
self.messagelist = [] # 存储多个交易记录
self.timestamp = None # 存储多个记录最终锁定时间
self.hash = None
self.preHash = None
if args:
for arg in args:
self.add_message(arg)
def add_message(self, message): # 添加 交易信息
# 区分第一条与后面多条,是否需要链接
if len(self.messagelist) > 0:
message.link(self.messagelist[-1]) # 链接最后一个
message.seal() # 密封
message.validate() # 校验
self.messagelist.append(message)
def link(self, block): # 区块链接
self.preHash = block.hash
def seal(self): # 密封当前hash
self.timestamp = datetime.datetime.now()
self.hash = self.hash_block()
def hash_block(self): # 密封上一块哈希,时间戳,交易记录的最后一个
return hashlib.sha512(
(str(self.timestamp) + str(self.preHash) + str(self.messagelist[-1].hash)).encode("utf-8")).hexdigest()
def validate(self): # 校验
for i, message in enumerate(self.messagelist): # 每个交易记录校验一下
message.validate() #每一条交易记录校验
if i > 0 and message.prev_hash != self.messagelist[i - 1].hash:
raise InvalidBlock("无效的block,交易记录被修改为在第{}条记录".format(i)+str(self))
return str(self) + "Ok"
def __repr__(self):
return "money block= hash:{},prehash:{},len:{},time:{}".format(self.hash, self.preHash, len(self.messagelist),
self.timestamp)
自定义异常:
class InvalidBlock(Exception):
def __init__(self,*args,**kwargs):
super(Exception,self).__init__(*args,**kwargs)
编写测试模块:
if __name__=="__main__":
t1 = Transaction("yicheng", "ddd1", 100)
t2 = Transaction("yicheng", "ddd2", 200)
t3 = Transaction("yicheng", "ddd3", 300)
t4 = Transaction("yicheng", "ddd4", 400)
m1 = DaDaMessage(t1)
m2 = DaDaMessage(t2)
m3 = DaDaMessage(t3)
m4 = DaDaMessage(t4)
try:
block1 = Block(m1, m2, m3)
block1.seal()
#测试篡改数据
#m3.data = "你妹的直播"
#block1.messagelist[0] = m3
print(block1.validate())
except InvalidMessage as e: #交易记录被修改
print(e)
except InvalidBlock as e: #区块被修改
print(e)
测试结果如下,为了打印需要,我改成了md5格式下的结果:
篡改区块信息的结果,可能结果不一样,因为修改的内容不一样,报的错误也不一样:
至此,已经完成了:交易记录,区块的开发,现在进行区块链的开发就比较容易了。实现代码如下:
from Block import InvalidBlock, Block
from Message import InvalidMessage, DaDaMessage
from Transaction import Transaction
# 区块链
class Dada_BlockCoin:
def __init__(self):
self.blocklist = [] # 装载所有区块
def validate(self):#校验所有区块
for i, block in enumerate(self.blocklist):
try:
block.validate()
except InvalidBlockCoin as e:
raise InvalidBlockCoin("区块校验错误,区块索引{}".format(i))
def add_block(self, block): # 增加区块
if len(self.blocklist) > 0:
block.link(self.blocklist[-1]) #连接区块
block.seal()#密封
block.validate()#校验
self.blocklist.append(block)#添加到区块链中
def __repr__(self):
return "Dada_BlockCoin:{}".format(len(self.blocklist))
自定义异常:
class InvalidBlockCoin(Exception):
def __init__(self, *args, **kwargs):
super(Exception, self).__init__(*args, **kwargs)
编写测试模块:
if __name__ == "__main__":
t1 = Transaction("yicheng", "ddd1", 100)
t2 = Transaction("yicheng", "ddd2", 200)
t3 = Transaction("yicheng", "ddd3", 300)
t4 = Transaction("yicheng", "ddd4", 400)
t5 = Transaction("yicheng", "ddd5", 500)
t6 = Transaction("yicheng", "ddd6", 600)
m1 = DaDaMessage(t1)
m2 = DaDaMessage(t2)
m3 = DaDaMessage(t3)
m4 = DaDaMessage(t4)
m5 = DaDaMessage(t5)
m6 = DaDaMessage(t6)
try:
yin1 = Block(m1, m2)
yin1.seal()
yin2 = Block(m3, m4)
yin2.seal()
yin3 = Block(m5, m6)
yin3.seal()
# 篡改区块
#yin3.messagelist.append(m1)
coin = Dada_BlockCoin() # 区块链
coin.add_block(yin1)
coin.add_block(yin2)
coin.add_block(yin3)
coin.validate()
print(coin)
except InvalidMessage as e:
print(e)
except InvalidBlock as e:
print(e)
except InvalidBlockCoin as e:
print(e)
测试结果如下:
篡改区块链,测试模块区块链的内容,可以任意篡改,测试结果如下:
这里已经完成了数据层的部分开发,其余部分后续会完善。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
python区块_python区块及区块链的开发详解相关推荐
- 海龟画图 python太阳花_python 简单的绘图工具turtle使用详解
目录 1. 画布(canvas) 1.1 设置画布大小 2. 画笔 2.1 画笔的状态 2.2 画笔的属性 2.3 绘图命令 3. 命令详解 4. 绘图举例 4.1 太阳花 4.2 绘制小蟒蛇 4.3 ...
- base6 python 字节_Python使用base64模块进行二进制数据编码详解
前言 昨天团队的学妹来问关于POP3协议的问题,所以今天稍稍研究了下POP3协议的格式和Python里面的poplib.而POP服务器往回传的数据里有一部分需要用到Base64进行解码,所以就顺便看了 ...
- python实验原理_Python实现蒙特卡洛算法小实验过程详解
蒙特卡洛算法思想 蒙特卡洛(Monte Carlo)法是一类随机算法的统称,提出者是大名鼎鼎的数学家冯·诺伊曼,他在20世纪40年代中期用驰名世界的赌城-摩纳哥的蒙特卡洛来命名这种方法. 通俗的解释一 ...
- 粒子群优化算法和python代码_Python编程实现粒子群算法(PSO)详解
1 原理 粒子群算法是群智能一种,是基于对鸟群觅食行为的研究和模拟而来的.假设在鸟群觅食范围,只在一个地方有食物,所有鸟儿看不到食物(不知道食物的具体位置),但是能闻到食物的味道(能知道食物距离自己位 ...
- 区块链开发指南_区块链软件开发详解
开发业务层区块链应用 Hyperledger fabric目前支持java,nodejs,go和python语言的sdk,供用户选择用不同的语言开发上层应用,使用相应的sdk调用部署在区块链上的链码. ...
- python菱形_python如何输出菱形与空心菱形详解与巧妙地使用center方法
首先应该了解菱形在输出时,每一行的组成有哪些规律,并且除了中间的一行,上部分和下半部分应该是对称的 这是一个我们要准备输出的一个菱形的模板 ,一共有7行 7列 我们设菱形上半部分的总行数为rows,当 ...
- python 连通域_python中验证码连通域分割的方法详解
实现思路 是用深度遍历,对图片进行二值化处理,先找到一个黑色像素,然后对这个像素的周围8个像素进行判断,如果没有访问过,就保存起来,然后最后这个数组的最小x和最大x就是x轴上的切割位置.这种分割的方法 ...
- python区块链开发_Fabric区块链Python开发详解
Hyperledger Fabric是最流行的联盟区块链平台.Fabric区块链Python开发详解课程 涵盖Fabric区块链的核心概念.Fabric网络搭建.Node链码开发.Python应用开发 ...
- Fabric区块链开发详解
Hyperledger是一个旨在推动区块链跨行业应用的开源项目,由Linux基金会在2015年12月主导发起该项目,成员包括金融.银行.物联网.供应链.制造和科技等多个行业的领头羊,托管了众多面向企业 ...
最新文章
- 玩转正则之highlight高亮
- Oracle 导出CSV、导出大数据
- IHelloWorldService
- 阿里云轻应用服务器 宝塔面板 mongodb 配置外网连接 其一 基础配置
- c++ 如何获取移动硬盘型号信息_工程销售,如何高效快速获取项目信息
- 关系抽取之远程监督算法:别再跟我提知识图谱(下篇)
- 如何使用免费工具构建有效的小型APP开发团队
- __VA_ARGS__和##__VA_ARGS__的区别(转载)
- 【Docker】在CentOS上安装
- 键盘视频鼠标(KVM)切换器基础知识
- 如何生成密钥,私钥,签名
- 电力猫服务器的网页,电力猫是如何工作的?
- app推送-极光推送
- (1)前言-JsDroid引流脚本混合式开发技术系列教程By飞云脚本学院
- java 文件删除不了_java的File类的 delete方法删不掉文件的原因分析
- 机器视觉软件开发SDK
- 517编程3380造素数
- Sublime Text 3 的 Markdown 实时预览全面总结
- CCF CSP 2019-9-1 小明种苹果 C语言100分
- 第3讲、Cadence原理图工程以及原理图库的创建
热门文章
- 一周新论文 | 2020年第10周 | 自然语言处理相关
- word实例教程:用表格快速制作座次表
- java程序语言设计课后答案向金海,看看这篇文章吧!
- 服务器显卡不能显示器,显卡与显示器的故障排除方法大全
- microbit python扩展_【micro:bit扩展】如何用慧编程扩展设计器为 micro:bit 编写扩展...
- 英特尔问题产品可无条件退换 或致硬盘光驱失灵
- Android学习方法和计划制定
- 免费知网万方数据论文下载
- PDFMaker文件遗失解决方法
- Android手机搜网列表名称显示流程