PHP實現區塊鏈

<?php
/**
 * 簡單的PHP區塊鏈
 */
namespace common\library\block;
/**
 * 區塊結構
 */
class block{
    private $index;
    private $timestamp;
    private $data;
    private $previous_hash;
    private $random_str;
    private $hash;
    public function __construct($index,$timestamp,$data,$random_str,$previous_hash)
    {
        $this->index=$index;
        $this->timestamp=$timestamp;
        $this->data=$data;
        $this->previous_hash=$previous_hash;
        $this->random_str=$random_str;
        $this->hash=$this->hash_block();
    }
    public function __get($name){
        return $this->$name;
    }
    private function hash_block(){
        $str=$this->index.$this->timestamp.$this->data.$this->random_str.$this->previous_hash;
        return hash("sha256",$str);
    }
}
/**
 * 創世區塊
 * @return \common\library\block\block
 */
function create_genesis_block(){
    return new \common\library\block\block(0, time(),"第一個區塊",0,0);
}
/**
 * 挖礦,生成下一個區塊
 * 這應該是一個複雜的算法,但爲了簡單,我們這裏挖到前1位是數字就挖礦成功。
 * @param \common\library\block\block $last_block_obj
 */
function dig(\common\library\block\block $last_block_obj){
    $random_str = $last_block_obj->hash.get_random();
    $index=$last_block_obj->index+1;
    $timestamp=time();
    $data='I am block '.$index;
    $block_obj = new \common\library\block\block($index,$timestamp,$data,$random_str,$last_block_obj->hash);

    //前一位不是數字
    if(!is_numeric($block_obj->hash{0})){
        return false;
    }
    //數數字,返回塊
    return $block_obj;
}
/**
 * 驗證區塊
 * 這也是一個複雜的過程,爲了簡單,我們這裏直接返回正確
 * @param array $data
 */
function verify(\common\library\block\block $last_block_obj){
    return true;
}
/**
 * 生成隨機字符串
 * @param int $len
 * @return string
 */
function get_random($len=32){
    $str="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
    $key = "";
    for($i=0;$i<$len;$i++)
    {
        $key.= $str{mt_rand(0,32)};//隨機數
    }
    return $key;
}


header("Content-type:text/html;charset=utf-8");
//生成第一個區塊
$blockchain=[\common\library\block\create_genesis_block()];
//模擬生成其他區塊,我們直接循環生成。實際中,還需要跟蹤互聯網上多臺機器上鍊的變化,像比特幣會有工作量證明等算法,達到條件了才生成區塊等
//我們的鏈是一個數組,實際生產中應該保存下來
$previous_block = $blockchain[0];
for($i=0;$i<=10;$i++){
    if(!($new_block=dig($previous_block))){
        continue;
    }
    $blockchain[]=$new_block;
    $previous_block=$new_block;

    //告訴大家新增了一個區塊
    echo "區塊已加入鏈中.新區塊是 : {$new_block->index}<br/>";
    echo "新區塊哈希值是 : {$new_block->hash}<br/>";
    print_r($new_block);
    echo "<br/><br/>";
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章