http://www.7klian.com

用Java构建本身的区块链

        return previousHash;
对付之后生成的每个新块,我们将利用前一个块的哈希值以及它本身的生意业务作为输入来确定它的块哈希值。
       System.out.println(“Block3 Hash:”+block3.getBlockHash());
        this.transactions = transactions;
    }
    public void setBlockHash(int blockHash) {
        }
发源块哈希值:1528835466
    public int getPreviousHash() {
        this.transactions = transactions;
它将相当容易捕捉任何改动的功效,因为您可以较量之前的哈希值。

Block2哈希值:-701393757
区块链中的第一个块是发源块。发源块险些老是硬编码到利用其区块链的应用措施的软件中。
    public static void main(String[] args) {
    private int previousHash;
将getter setter要领应用到变量块类后,如下所示:
一旦你加密了数据,你可以通过解密获得它,不像在哈希值中你不能通过任何要领获得输入。
此刻我们建设一个区块链。
        System.out.println(“Genesis Block Hash:”+genesisBlock.getBlockHash());
Block3哈希值:1918912447
        Block genesisBlock = new Block(0,genesisTransactions);

如;
import java.util.Arrays;
差异的哈希函数利用差异的算法来生成哈希值。
    }        
此刻让我们看一看区块链如何使它不行能改变一个块的哈希值,以便一旦一个块被写到区块链中,它就不能改变。
  blockHash = Arrays.hashCode(contents);
有时你大概想知道为什么需要像SHA256(安详哈希算法)这样的哈希算法?
Block3哈希值:-716750945
Block2哈希值:957910147
    public void setTransactions(String[] transactions) {
    }
        this.previousHash = previousHash;
{
这就是块链的形成方法,每个新的块哈希值指向它之前的块哈希值。这个哈希系统担保汗青上的任何生意业务都不会被改动,因为假如生意业务的任何一个部门产生了变革,那么它所属的块的哈希值也会产生变革,功效会导致后头的块的哈希值也会产生变革。
记着,哈希值不是加密。
       String[] block3Transactions = {“Alex sent 999 bitcoins to non”};
        this.blockHash = Arrays.hashCode(contents);
        this.previousHash = previousHash;
另外,对付任何特定的输入,哈希函数老是给出沟通的输出。可是,假如你在输入中做一个很小的改变,所发生的哈希值将与前一个完全差异。
发源块哈希值:-1106827926
所以主类是这样的:
        Object[] contents = {Arrays.hashCode(transactions),previousHash};
import java.util.ArrayList;
· 哈希值(int)
        this.blockHash = blockHash;
    private int blockHash;

留意:这只是一个演示区块链,,真正的区块链涉及到许多其他对象,如共鸣机制、数字签名、Merkle树等。这个代码示例将有助于实现抱负的目标。
        System.out.println(“Block2 Hash:”+block2.getBlockHash());
    public void setPreviousHash(int previousHash) {
    ArrayList<Block> blockchain = new ArrayList<>();
    public String[] getTransactions() {
将发源块生意业务中“Suraj”的“S”变动为“s”后输出:
· 前一块哈希值(String [])
Object[] contents ={Arrays.hashCode(transactions),previousHash};
我们将建设一个块类。每个块将有:
       Block block3 = new Block(block2.getBlockHash(), block3Transactions);
}
 }
}
    }
您可以输出发源块的哈希值,然后变动它,您将看到输出与之前的输出有很大的差异,纵然您变动了生意业务串中单个字母的巨细写。
最重要的原因是,这些算法辅佐我们制止斗嘴(差异输入的相似哈希值)。
    }
· 列表的生意业务(int)
        String[] block2Transactions = {“John sent 10 bitcoins to Suraj”,”Suraj sent 10 bitcoins to Alex”};
        return blockHash;
哈希函数是一种数学函数,它接管任意长度的数值数据的输入,并将其转换为牢靠长度的数值数据。
        Block block2= new Block(genesisBlock.getBlockHash(), block2Transactions);
输出:
    public int getBlockHash() {
        return transactions;
实际区块链中的生意业务必定是一些生意业务类,将利用差异的数据布局。为了简朴起见,我将它们写成字符串。
    private String[] transactions;
        String[] genesisTransactions = {“Suraj sent Ruja 1542 Bitcoins”,”Ruja sent 10 Bitcoins to John”};
    public Block(int previousHash, String[] transactions) {

众所周知,是不行变的。在这里,我们将设计一个简朴的区块链,它将辅佐您领略哈希值如何只用几行Java代码就使区块链变得不行变。

public class Blockchain {
public class Block 
我们将从建设一个发源块开始。由于发源块是链中的第一个块,我们将硬编码生意业务到前面的哈希值。
    
    }

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

相关文章阅读