python区块链简单模拟【03】

这篇具有很好参考价值的文章主要介绍了python区块链简单模拟【03】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

引入钱包,账户地址,公私钥

# 导入椭圆曲线算法
from ecdsa import SigningKey, SECP256k1, VerifyingKey, BadSignatureError
import binascii
import base64
from hashlib import sha256


class Wallet:
    """
        钱包
    """
    def __init__(self):
        """
            钱包初始化时基于椭圆曲线生成一个唯一的秘钥对,代表区块链上一个唯一的账户
        """
        self._private_key = SigningKey.generate(curve=SECP256k1)   #私钥  签名
        self._public_key = self._private_key.get_verifying_key()   #公钥  验证 

    @property    #通过 @property 装饰器,可以直接通过方法名来访问方法,不需要在方法名后添加一对“()”小括号。
    def address(self):
        """
            这里通过公钥生成地址
            base64.b64encode()将bytes类型数据进行base64编码,返回编码后的bytes类型
            base64.b64deocde()将base64编码的bytes类型进行解码,返回解码后的bytes类型、
            常见于网址url加密中
        """
        h = sha256(self._public_key.to_pem())
        return base64.b64encode(h.digest())  #返回16进制sha256哈希加密后的哈希值并对其进行编码

    @property
    def pubkey(self):
        """
            返回公钥字符串
        """
        return self._public_key.to_pem()

    def sign(self, message):
        """
            生成数字签名
        """
        h = sha256(message.encode('utf8'))
        return binascii.hexlify(self._private_key.sign(h.digest()))  #二进制输出

    
def verify_sign(pubkey, message, signature):
    """
        验证签名
    """
    verifier = VerifyingKey.from_pem(pubkey)
    h = sha256(message.encode('utf8'))
    return verifier.verify(binascii.unhexlify(signature), h.digest())

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# 新建一个钱包

w = Wallet()

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# 打印钱包地址  
w.address

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# 打印钱包公钥

w.pubkey

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# 测试数据

data = "交易数据"
# 生成签名

sig = w.sign(data)

# 打印签名
print(sig)

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# 验证签名

verify_sign(w.pubkey, data, sig)

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

import json

class Transaction:
    """
    交易的结构
    """
    def __init__(self, sender, recipient, amount):
        """
            初始化交易,设置交易的发送方、接收方和交易数量
        """
        if isinstance(sender, bytes):
            sender = sender.decode('utf-8')
        self.sender = sender            # 发送方
        if isinstance(recipient, bytes):
            recipient = recipient.decode('utf-8')
        self.recipient = recipient      # 接收方
        self.amount = amount            # 交易数量
        
    def set_sign(self, signature, pubkey):
        """
            为了便于验证这个交易的可靠性,需要发送方输入他的公钥和签名
        """
        self.signature = signature      # 签名
        self.pubkey = pubkey            # 发送方公钥  提供给验证者和接收方用来验证交易
        
    def __repr__(self):
        """
            交易大致可分为两种,一是挖矿所得,而是转账交易
            挖矿所得无发送方,以此进行区分显示不同内容
        """
        if self.sender:           #发送方不为空,则是转账交易   
            s = "从 %s 转至 %s %d个加密货币" % (self.sender, self.recipient, self.amount)
        else:                     #否则是挖矿所得
            s = "%s 挖矿获取%d个加密货币" % (self.recipient, self.amount)
        return s


class TransactionEncoder(json.JSONEncoder):
    """
    定义Json的编码类,用来序列化Transaction
    """
    def default(self, obj):
        if isinstance(obj, Transaction):
            return obj.__dict__
        else:
            return json.JSONEncoder.default(self, obj)

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言`import hashlib
from datetime import datetime

class Block:
“”"
区块结构
prev_hash: 父区块哈希值
transactions: 交易列表
timestamp: 区块创建时间
hash: 区块哈希值
Nonce: 随机数
“”"
def init(self, transactions, prev_hash):
# 将传入的父哈希值和数据保存到类变量中
self.prev_hash = prev_hash
self.transactions = transactions
# 获取当前时间
self.timestamp = datetime.now().strftime(“%Y-%m-%d %H:%M:%S”)

    # 设置Nonce和哈希的初始值为None
    self.nonce = None
    self.hash = None
    
def __repr__(self):
    return "区块内容:%s\n哈希值: %s" % (json.dumps(self.transactions), self.hash)`

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

class ProofOfWork:
    """
        工作量证明
        简化为一个挖矿者,只要挖矿就一定能挖到,只是时间问题
    """
    def __init__(self, block, miner, difficult=5):
        self.block = block
        
        # 定义工作量难度,默认为5,表示有效的哈希值以5个“0”开头
        self.difficulty = difficult

        self.miner = miner
        
        # 添加挖矿奖励
        self.reward_amount = 1  #奖励一个加密货币

    def mine(self):
        """
            挖矿函数
        """
        i = 0                            #初始化随机值
        prefix = '0' * self.difficulty   #设置难度
        
        
        # 添加奖励                    新建挖矿交易
        t = Transaction(
                sender="",
                recipient=self.miner.address,
                amount=self.reward_amount,
            )
        sig = self.miner.sign(json.dumps(t, cls=TransactionEncoder))    #钱包类中的账户使私钥签名
        t.set_sign(sig, self.miner.pubkey)                              #发送签名和公钥
        self.block.transactions.append(t)                               #将交易添加到区块链中交易列表中

        while True:
            message = hashlib.sha256()
            message.update(str(self.block.prev_hash).encode('utf-8'))
            # 更新区块中的交易数据
            # message.update(str(self.block.data).encode('utf-8'))
            message.update(str(self.block.transactions).encode('utf-8'))
            message.update(str(self.block.timestamp).encode('utf-8'))
            message.update(str(i).encode("utf-8"))
            digest = message.hexdigest()
            if digest.startswith(prefix):
                self.block.nonce = i
                self.block.hash = digest
                return self.block
            i += 1

    def validate(self):
        """
            验证有效性
        """
        message = hashlib.sha256()
        
        #四句话将区块各个参数进行哈希运算
        message.update(str(self.block.prev_hash).encode('utf-8'))
        # 更新区块中的交易数据
        # message.update(str(self.block.data).encode('utf-8'))
        message.update(json.dumps(self.block.transactions).encode('utf-8'))
        message.update(str(self.block.timestamp).encode('utf-8'))
        message.update(str(self.block.nonce).encode('utf-8'))
        
        digest = message.hexdigest()  #16进制输出hash值

        prefix = '0' * self.difficulty
        return digest.startswith(prefix)   #验证是否为符合难度的哈希值

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

class BlockChain:
    """
        区块链结构体
            blocks:        包含的区块列表
    """
    def __init__(self):
        self.blocks = []

    def add_block(self, block):
        """
        添加区块
        """
        self.blocks.append(block)
    
    def print_list(self):
        print("区块链包含区块个数: %d\n" % len(self.blocks))
        for block in self.blocks:
            print("上个区块哈希:%s" % block.prev_hash)
            print("区块内容:%s" % block.transactions)
            print("区块哈希:%s" % block.hash)
            print("\n") 

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

def get_balance(user):
    balance = 0
    for block in blockchain.blocks:
        for t in block.transactions:
            if t.sender == user.address.decode():
                balance -= t.amount
            elif t.recipient == user.address.decode():
                balance += t.amount
    return balance

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# 初始化区块链
blockchain = BlockChain()

# 创建三个钱包,一个属于alice,一个属于tom,剩下一个属于bob
alice = Wallet()
tom = Wallet()
bob = Wallet()

# 打印当前钱包情况
print("alice: %d个加密货币" % (get_balance(alice)))
print("tom: %d个加密货币" % (get_balance(tom)))
print("bob: %d个加密货币" % (get_balance(bob)))

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# alice生成创世区块,并添加到区块链中

new_block1 = Block(transactions=[], prev_hash="")
w1 = ProofOfWork(new_block1, alice)
genesis_block = w1.mine()
blockchain.add_block(genesis_block)
# 显示alice当前余额

print("alice: %d个加密货币" % (get_balance(alice)))

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# alice 转账给 tom 0.3个加密货币
transactions = []
new_transaction = Transaction(
    sender=alice.address,
    recipient=tom.address,
    amount=0.3
)
sig = tom.sign(str(new_transaction))       #私钥签名
new_transaction.set_sign(sig, tom.pubkey)  #发送签名和公钥

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言

# bob 在网络上接收到这笔交易,进行验证没问题后生成一个新的区块并添加到区块链中

if verify_sign(new_transaction.pubkey, 
                  str(new_transaction),
                   new_transaction.signature):    #验证者验证
    
    # 验证交易签名没问题,生成一个新的区块
    print("验证交易成功")
    new_block2 = Block(transactions=[new_transaction], prev_hash="")
    print("生成新的区块...")
    w2 = ProofOfWork(new_block2, bob)
    block = w2.mine()                              #bob挖矿,找到新的区块将其写入区块链
    print("将新区块添加到区块链中")
    blockchain.add_block(block)
else:
    print("交易验证失败!")

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言# 打印当前钱包情况 print("alice: %.1f个加密货币" % (get_balance(alice))) print("tom: %.1f个加密货币" % (get_balance(tom))) print("bob: %d个加密货币" % (get_balance(bob)))

python区块链简单模拟【03】,区块链模拟,python,区块链,开发语言文章来源地址https://www.toymoban.com/news/detail-779040.html

到了这里,关于python区块链简单模拟【03】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • go语言简单实现区块链

            在本文中,我们将使用Go语言来实现一个简单的区块链系统,包括区块生成、交易处理和区块打印、保存区块链等功能。 在开始之前,先确保计算机上安装了以下内容: Go编程语言:您可以从Go官方网站下载并安装Go。 Go开发环境:设置Go开发环境,包括文本编辑器

    2024年04月16日
    浏览(39)
  • C语言 03 VSCode开发

    安装好 C 语言的开发环境后,就需要创建项目进行开发了。 使用 IDE(集成开发环境)进行开发了。 C 语言的开发工具很多,现在主流的有 Clion、Visual Studio、VSCode。 这里以 VSCode 作为演示。 安装 VSCode。 推荐直接在微软的应用市场安装: 安装插件。 安装好 VSCode 后,在它的插

    2024年04月09日
    浏览(36)
  • 【HarmonyOS北向开发】-03 ArkTS开发语言-TypeScript快速入门

     飞书原文链接:Docs

    2024年02月12日
    浏览(51)
  • vue尚品汇商城项目-day03【vue插件-19.mockjs模拟数据(开发Home首页当中的ListContainer组件与Floor组件)】

    安装命令:cnpm install --save mockjs 重难点说明 使用swiper实现静态页面轮播 解决多个swiper冲突的问题 解决swiper动态页面轮播的bug 定义可复用的轮播组件 解决Floor组件中轮播有问题的bug 利用mockjs提供模拟数据 Mockjs: 用来拦截ajax请求, 生成随机数据返回 学习 ​ a. http://mockjs.com/ ​

    2023年04月09日
    浏览(53)
  • 【数据分析:语言篇】Python(03)创建Python虚拟环境

    根据实际开发需求,我们会不断的更新或卸载项目中依赖的Python类库,直接对我们的Python环境操作会让我们的开发环境和项目造成很多不必要的麻烦,并且当我们同时开发多个项目的时候,可能每个项目依赖的同一个Python库的版本还不一样,就会造成版本冲突,管理相当混乱

    2024年02月03日
    浏览(75)
  • python实现简单的区块链

    运用datetime和hashlib模拟实现区块链 区块函数 包含区块高度标识:blockNo 交易数据:data nonce值 preious_hash:上一个区块哈希 timestamp:当前时间 链函数 分别包括三个方法,添加块的方法、挖矿功能、以及打包交易 添加块的方法: 挖矿功能(采用的是工作量证明共识机制) 打包交

    2024年02月06日
    浏览(38)
  • 用python搭建简单的区块链

    以下是使用Python编写简单的区块链的步骤: 安装需要的库 创建区块链的类 创建创世块和区块的添加方法 创建Flask Web应用程序 运行应用程序并测试 运行应用程序: 使用POST请求创建新的交易: 使用GET请求获取完整的区块链: 使用GET请求挖掘新的区块: 以上就是使用Python编

    2024年04月26日
    浏览(32)
  • 【Python】实现一个简单的区块链系统

    本文章利用 Python 实现一个简单的功能较为完善的区块链系统(包括区块链结构、账户、钱包、转账),采用的共识机制是 POW。 Block.py  BlockChain.py  测试结果  将工作量证明加入到 Block.py 中 测试结果 更新 BlockChain.py  测试结果  实现钱包、账户、交易功能要先安装非对称加

    2024年02月11日
    浏览(42)
  • 区块链实战:用python编写最简单的比特币区块链本地测试框架

    比特币本身并不是特别复杂,中本聪的白皮书只有十页左右。 可从该链接下载(有各种语言版本):Bitcoin: A Peer-to-Peer Electronic Cash System 但是,真正投入使用的比特币系统实际上非常复杂,包含诸多因素,涉及诸多细节,甚至对一个手续费机制研究几天还云里雾里。 如何有效地

    2024年02月05日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包