>백엔드 개발 >PHP 튜토리얼 >PHP는 블록체인(소스 코드 포함)을 구축합니다.

PHP는 블록체인(소스 코드 포함)을 구축합니다.

烟雨青岚
烟雨青岚원래의
2020-06-13 18:07:275424검색

PHP는 블록체인(소스 코드 포함)을 구축합니다.

php는 블록체인을 구축합니다(소스 코드 포함)

우리는 PHP 프로그래밍 언어를 사용하여 블록체인을 구축할 예정입니다. 블록체인 자체는 매우 간단한 개념이며 매우 간단한 데이터 구조, 디지털입니다. 통화는 매우 복잡하지만 블록체인은 그렇지 않습니다. 복잡한 이유는 합의 알고리즘, 채굴 메커니즘 및 그 위에서 실행되는 모든 것입니다. 그러나 블록체인 자체는 블록체인을 실제로 이해하기 전까지는 이해하기 매우 쉽습니다. 체인이 어떻게 작동하는지 먼저 알아야 합니까? 해싱에 대해 무엇을 알아야 합니까? 어떻게 작동하나요?

해시는 기본적으로 일종의 데이터에 대한 디지털 서명입니다. 예를 들어 영화를 찍고 해시하고 디지털 서명을 받을 수 있으며 이메일을 해시하고 디지털 서명을 받을 수 있습니다. 또한 단어를 해시할 수도 있고, 어떤 데이터든 가져와서 해시할 수 있으며, 해시 값을 얻을 수도 있습니다. 해당 데이터에 디지털 서명만 하면 됩니다.

이 해시는 실제로 어떻게 작동하나요? 좀 더 자세히 살펴보겠습니다.

우리는 PHP로 블록체인을 구축할 예정입니다. 매우 간단할 것입니다. 프로그래밍에 대해 조금 알고 있다면 다른 언어로 할 수 있고, 프로그래밍을 모르더라도 여전히 그럴 것이라고 생각합니다. 대략적으로 작동 방식을 이해하기 위해 해싱에 대해 이야기해 보겠습니다.

<?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를 포함하는 두 개의 목록이 있습니다. 이것이 데이터이고 이것이 우리가 해시하려는 문자열입니다. 목록에서 무엇을 얻는지 봅시다. 어떤 종류의 디지털 서명은 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

완전히 다른 디지털 서명을 얻게 되므로 조금만 변경하면 데이터에 개입하여 이 목록의 무엇이든 변경하려고 하면 완전히 다른 디지털 서명을 받게 됩니다. 이것이 블록체인 기술의 기초입니다. 왜냐하면 블록체인은 블록 목록, 기본적으로 블록 목록이기 때문입니다. 연결된 리스트를 구성하고 각 블록은 이전 블록의 전자서명을 유지하며, 다음 블록의 전자서명은 현재 블록의 전자서명을 기반으로 하므로 항상 서로 연관되어 있으며, 다음 블록의 전자서명은 현재 블록의 전자서명을 기반으로 합니다. 서명과 현재 서명은 이전 서명을 기반으로 하므로 과거에 무엇이든 변경하면 모든 서명이 깨지고 완전히 다르게 보일 것입니다.

코딩 방법

실제로 블록체인 코딩에 들어가 보겠습니다. 가장 먼저 해야 할 일은 블록 클래스에 대해 이야기하는 것입니다. 이 경우 블록은 매우 간단합니다. 세 가지만 포함합니다. 해당 블록에서 발생한 거래 목록을 포함하고 이전 블록의 이전 해시 또는 디지털 서명을 포함하며 해시 자체도 포함하며 이 해시는 거래 및 이전 해시를 기반으로 하므로 누구든지 이전 블록의 내용이 변경되면 현재 블록의 디지털 서명이 변경되고 다음 블록의 디지털 서명도 변경됩니다.

원하는 IDE를 사용하여 빈 PHP 프로젝트를 다시 생성합니다. 저는 localhost 환경에서 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教程

위 내용은 PHP는 블록체인(소스 코드 포함)을 구축합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.