主頁 > 知識(shí)庫 > 詳解python實(shí)現(xiàn)簡(jiǎn)單區(qū)塊鏈結(jié)構(gòu)

詳解python實(shí)現(xiàn)簡(jiǎn)單區(qū)塊鏈結(jié)構(gòu)

熱門標(biāo)簽:地圖標(biāo)注的意義點(diǎn) 上海機(jī)器人外呼系統(tǒng)哪家好 蓋州市地圖標(biāo)注 浙江電銷卡外呼系統(tǒng)好用嗎 地圖標(biāo)注微信發(fā)送位置不顯示 南京銷售外呼系統(tǒng)軟件 地圖制圖標(biāo)注位置改變是移位嗎 315電話機(jī)器人廣告 房產(chǎn)電銷外呼系統(tǒng)

區(qū)塊鏈

比特幣從誕生到現(xiàn)在已經(jīng)10年了,最近接觸到了區(qū)塊鏈相關(guān)的技術(shù),為了揭開其背后的神秘面紗,我就從頭開始構(gòu)建一個(gè)簡(jiǎn)單的區(qū)塊鏈。

從技術(shù)上來看:區(qū)塊是一種記錄交易的數(shù)據(jù)結(jié)構(gòu),反映了一筆交易的資金流向。系統(tǒng)中已經(jīng)達(dá)成的交易的區(qū)塊連接在一起形成了一條主鏈,所有參與計(jì)算的節(jié)點(diǎn)都記錄了主鏈或主鏈的一部分。

一、比特幣內(nèi)部結(jié)構(gòu)

比特幣內(nèi)部結(jié)構(gòu)有四部分:

  1. previous hash: 上一個(gè)區(qū)塊的hash
  2. data:交易數(shù)據(jù)
  3. time stamp:區(qū)塊生成的時(shí)間戳
  4. nonce:挖礦計(jì)算次數(shù)

二、實(shí)現(xiàn)的比特幣結(jié)構(gòu)

  1. index :當(dāng)前區(qū)塊索引
  2. timestamp :該區(qū)塊創(chuàng)建時(shí)的時(shí)間戳
  3. data :交易信息
  4. previous hash: 前一個(gè)區(qū)塊的hash
  5. hash: 當(dāng)前區(qū)塊的hash
  6. nonce : 挖礦計(jì)算次數(shù)

注意:當(dāng)前實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的區(qū)塊鏈結(jié)構(gòu),并不完整。

三、代碼實(shí)現(xiàn)

1.定義區(qū)塊的結(jié)構(gòu)

代碼如下:

"""
區(qū)塊設(shè)計(jì)
"""
import time
import hashlib

class Block:
    # 初始化一個(gè)區(qū)塊
    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()
    # 獲取區(qū)塊的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()
    # 修改區(qū)塊的hash值
    def set_hash(self,hash):
        self.hash = hash

2.創(chuàng)世區(qū)塊構(gòu)造

創(chuàng)世區(qū)塊:沒有前一個(gè)區(qū)塊,這里的previous_hashdata是自己寫死的。

# 生成創(chuàng)世區(qū)塊,這是第一個(gè)區(qū)塊,沒有前一個(gè)區(qū)塊
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()函數(shù)是后面的挖礦函數(shù).

3.挖礦函數(shù)定義

代碼如下:

def mime(block):
    """
    挖礦函數(shù)——更新區(qū)塊結(jié)構(gòu),加入nonce值
        block:挖礦區(qū)塊
    """
    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.定義區(qū)塊鏈結(jié)構(gòu)

代碼如下:

"""
區(qū)塊鏈設(shè)計(jì)
"""
from Block import *
# 區(qū)塊鏈
class BlockChain:
    def __init__(self):
        self.blocks = [creat_genesis_block()]
    # 添加區(qū)塊到區(qū)塊鏈上
    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

在添加新區(qū)塊到區(qū)塊鏈時(shí),先挖礦在將新區(qū)塊加入?yún)^(qū)塊鏈。

四、代碼運(yùn)行

測(cè)試代碼:

from BlockChain import *
# 創(chuàng)建一個(gè)區(qū)塊鏈
bc = BlockChain()
# 添加區(qū)塊
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')

運(yùn)行結(jié)果:

這里添加了4個(gè)區(qū)塊(包括創(chuàng)世區(qū)塊),處了創(chuàng)世區(qū)塊,每個(gè)區(qū)塊的pre_hash都與前一個(gè)區(qū)塊的hash值相等,這代表區(qū)塊沒有被篡改,數(shù)據(jù)有效。

到此這篇關(guān)于python實(shí)現(xiàn)簡(jiǎn)單區(qū)塊鏈結(jié)構(gòu)的文章就介紹到這了,更多相關(guān)python區(qū)塊鏈結(jié)構(gòu)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python區(qū)塊及區(qū)塊鏈的開發(fā)詳解
  • python簡(jiǎn)單區(qū)塊鏈模擬詳解
  • Python實(shí)現(xiàn)基于POS算法的區(qū)塊鏈
  • Python實(shí)現(xiàn)類似比特幣的加密貨幣區(qū)塊鏈的創(chuàng)建與交易實(shí)例
  • 使用Python從零開始擼一個(gè)區(qū)塊鏈
  • Python從零開始創(chuàng)建區(qū)塊鏈
  • 用不到50行的Python代碼構(gòu)建最小的區(qū)塊鏈
  • Python學(xué)習(xí)入門之區(qū)塊鏈詳解
  • 如何用用Python制作NFT區(qū)塊鏈作品

標(biāo)簽:克拉瑪依 金華 臨汾 貴州 陽泉 雙鴨山 赤峰 日照

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解python實(shí)現(xiàn)簡(jiǎn)單區(qū)塊鏈結(jié)構(gòu)》,本文關(guān)鍵詞  詳解,python,實(shí)現(xiàn),簡(jiǎn)單,區(qū)塊,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解python實(shí)現(xiàn)簡(jiǎn)單區(qū)塊鏈結(jié)構(gòu)》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解python實(shí)現(xiàn)簡(jiǎn)單區(qū)塊鏈結(jié)構(gòu)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章