php構建一個區塊鏈(含原始碼)

2020-07-16 10:05:58

php構建一個區塊鏈(含原始碼)

我們要用PHP程式語言構建區塊鏈,區塊鏈本身就是一個非常簡單的概念,它是一個非常簡單的資料結構,數位貨幣是很複雜,但區塊鏈不是,它們複雜的原因是共識演算法,挖礦機制和執行在他們之上的一切,但區塊鏈本身是很容易理解的,在你真正了解區塊鏈是如何工作的之前,你需要知道什麼,你需要知道什麼是雜湊hash?它們是如何工作的?

雜湊基本上是某種資料的數位簽章,例如可以拍一部電影,可以hash它並得到一個數位簽章;可以拿一封電子郵件,可以把它hash並得到一個數位簽章;還可以拿一個字,也可以hash它,你可以拿任何資料,然後hash它,你都可以得到一個hash值。它只是對該資料進行數位簽章。

這個hash雜湊實際上是如何工作的?讓我們深入了解下。

我們將在PHP中構建區塊鏈,這將非常簡單,如果你懂一點兒程式設計,你也可以用另一種語言來做,如果你不懂程式設計,我想你仍然能夠大致理解它是如何工作的,所以讓我們來談談雜湊hash。

<?php
    $list1 = ["a","b","c"];
    $list2 = ["a","b","c"];
    echo "list 1: ".md5(serialize($list1));
    echo "<br/>list 2: ".md5(serialize($list2));
?>

正如你所看到的,我們有兩個列表,我們有兩個包含a、b、c的列表,這是資料,這是我們試圖hash的字串,讓我們看看我們從列表1和2中得到什麼樣的數位簽章。

輸出結果:

list 1: ec10e0c7a344da191700ab4ace1a5e26
list 2: ec10e0c7a344da191700ab4ace1a5e26

你可以看到,當我們得到這兩個雜湊字串或數位簽章,這兩個是相同的。

如果我現在改變list1中的內容,例如:

<?php
    $list1 = ["aaa","b","c"]; //Changed
    $list2 = ["a","b","c"];
    echo "list 1: ".md5(serialize($list1));
    echo "<br/>list 2: ".md5(serialize($list2));
?>

現在我在執行它:

list 1: 97f4361000fdba1732a50f1771c9d830
list 2: ec10e0c7a344da191700ab4ace1a5e26

你可以看到我們得到了完全不同的數位簽章,所以如果我只是做一個小的修改,我只是干預資料,我試圖改變這個列表中的任何東西,我將得到完全不同的數位簽章,這是區塊鏈技術的基礎,因為區塊鏈是一個塊的列表,基本上是一個由區塊組成的連結串列和每個塊保持前一個塊的數位簽章,並且下一個塊的數位簽章是基於當前塊的數位簽章,所以它們總是關聯在一起,下一個簽名將基於當前簽名而當前簽名是基於以前的簽名,所以如果你改變過去的任何東西,你會打破所有的簽名,他們將看起來完全不同。

如何編碼

讓我們實際進入我們的區塊鏈編碼,我們需要做的第一件事是談論我們的Block類,在這種情況下,我們的塊將非常簡單,它只包含三個東西,它將包含在該塊中發生的交易列表,它將包含先前的雜湊或數位簽章的前一個塊,它也將包含雜湊的本身,這個雜湊將基於交易和以前的雜湊,所以如果任何人改變任何東西在前一塊,數位簽章的當前塊將改變,並改變下一個塊的數位簽章。

使用你喜歡的IDE重新生成空的PHP專案,我在本地主機環境中使用XAMPP。

現在建立一個新的檔案block.php,並在其中放入下面的程式碼片段。

<?php
    class Block{
              private $previousHash;
              private $transactions=[];
              private $blockHash;
              function __construct($previousHash,$transactions){
                             $this->previousHash = $previousHash;
                             $this->transactions = $transactions;
                             $contents = [md5(serialize($transactions)),$previousHash];
                             $this->blockHash = md5(serialize($contents));
              }
              function getPreviousHash(){
                             return $this->previousHash;
              }
              function getTransactions(){
                             return $this->transactions;
              }
              function getBlockHash(){
                             return $this->blockHash;
              }
    }
?>

現在建立另一個名為index.php的檔案,並使用block.php類來建立一些塊。

index.php

<?php
    include("block.php");
    $genesisTransaction = ["a sends 11 bitcoins to b","b sends 44 bitcoins to c"];
    $genenisBlock = new Block(0, $genesisTransaction);
    $block1Transaction = ["a sends 11 bitcoins to b","b sends 44 bitcoins to c"];
    $block1 = new Block($genenisBlock->getBlockHash(), $block1Transaction);
    $block2Transaction = ["a sends 11 bitcoins to b","b sends 44 bitcoins to c"];
    $block2 = new Block($block1->getBlockHash(), $block2Transaction);
    echo "Genesis Block: ".$genenisBlock->getBlockHash();
    echo "<br/>Block 1: ".$block1->getBlockHash();
    echo "<br/>Block 2: ".$block2->getBlockHash();
?>

輸出結果:

Genesis Block: d9c559b57e148b19802d8e70555f0303
Block 1: 29e9e5a309aae81243fdf73112253c74
Block 2: fbff8f664f6b4069bf7288cb1b86cb3a

請看當前雜湊將基於以前的雜湊,如果你改變了任何先前的交易,你的所有數位簽章將生效,例如,在genesisTransaction中,我改變了11到12,它將輸出完全不同的,如:

<?php
    include("block.php"); 
    $genesisTransaction = ["a sends 12 bitcoins to b","b sends 44 bitcoins to c"]; //changed 11 to 12
    $genenisBlock = new Block(0, $genesisTransaction);
    $block1Transaction = ["a sends 11 bitcoins to b","b sends 44 bitcoins to c"];
    $block1 = new Block($genenisBlock->getBlockHash(), $block1Transaction);
    $block2Transaction = ["a sends 11 bitcoins to b","b sends 44 bitcoins to c"];
    $block2 = new Block($block1->getBlockHash(), $block2Transaction);
    echo "Genesis Block: ".$genenisBlock->getBlockHash();
    echo "<br/>Block 1: ".$block1->getBlockHash();
    echo "<br/>Block 2: ".$block2->getBlockHash();
?>

輸出結果:

Genesis Block: d9c559b57e148b19802d8e70555f0303
Block 1: 29e9e5a309aae81243fdf73112253c74
Block 2: fbff8f664f6b4069bf7288cb1b86cb3a

你可以看到任何一個交易的變化,在一個塊中的任何一個資料將傳播和改變未來的區塊鏈中所有的數位簽章,這就是區塊鏈的工作原理,因為如果我改變了什麼,每個人都會看到我的數位簽章完全不同於其他人,所以這意味著我在欺騙別人。就如同我告訴每個人,嘿,一個人給了我很多位元幣,這裡是區塊鏈,請每個人確認下。每個人將檢視它並說清楚,我們知道這個區塊鏈無法確認這一點,因為我們有自己版本的區塊鏈,數位簽章會是完全不同,所以這不行。

我希望你能理解通過它們的數位簽章將區塊的雜湊連結在一起的這一基本概念。在你的PHP中實現這個例子吧。

本文轉自:https://blog.csdn.net/mongo_node/article/details/81700425

以上就是php構建一個區塊鏈(含原始碼)的詳細內容,更多請關注TW511.COM其它相關文章!