Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimana untuk menilai blockchain yang dilaksanakan dalam JavaScript?

Bagaimana untuk menilai blockchain yang dilaksanakan dalam JavaScript?

PHPz
PHPzke hadapan
2023-08-27 21:05:07909semak imbas

blockchain ialah blockchain yang mengandungi maklumat. Pada tahun 2009, teknologi ini kemudiannya diterima pakai oleh Satoshi Nakamoto untuk mencipta mata wang kripto digital Bitcoin. Ini terbuka sepenuhnya kepada sesiapa sahaja yang ingin membangunkan atau menganalisis. Satu perkara tentang teknologi ini ialah apabila data tertentu direkodkan dalam blokchain, mengubahnya menjadi sangat rumit. Berikut adalah beberapa istilah yang digunakan untuk penilaian dalam program blockchain.

  • Block

    - Satu blok dalam blockchain mengandungi maklumat seperti data, nilai cincangan dan nilai cincang blok sebelumnya.

  • Data

    - Data ini bergantung sepenuhnya pada jenis blok, contohnya mata wang kripto mempunyai maklumat seperti dari siapa transaksi itu, kepada siapa transaksi itu dan jumlah transaksi . Syiling telah didagangkan.

  • Hash

    - Ini ialah ID rentetan unik seperti nombor Aadhar yang boleh digunakan untuk mencari butiran orang seperti cincang ini Sama untuk mengenal pasti butiran blok. Sebaik sahaja blok dibuat, cincangnya dibuat. Menukar cincang blok mudah dikenal pasti. Sebaik sahaja cincangan blok berubah, ia bukan lagi blok yang sama.

  • Previous Hash

    - Ini ialah cincangan blok sebelumnya dan digunakan untuk menyambung atau mencipta rantaian blok.

  • Dalam imej di atas, anda boleh melihat bahawa cincang sebelumnya mempunyai cincangan blok sebelumnya. Blok pertama juga dipanggil blok genesis kerana ia tidak boleh menunjuk ke blok sebelumnya. Jika anda menukar cincang, blok seterusnya dengan cincang sebelumnya akan menjadi tidak sah kerana perubahan itu.

Pakej yang akan kami gunakan ialah

crypto.js.

Ini ialah perpustakaan JavaScript yang menyediakan algoritma dan fungsi penyulitan. Ia boleh digunakan untuk melaksanakan pelbagai operasi kriptografi seperti pencincangan, penyulitan, penyahsulitan dan penjanaan kunci dalam penyemak imbas web atau dalam persekitaran JavaScript sebelah pelayan seperti Node.js. Pustaka ini digunakan secara meluas dalam aplikasi web untuk menyediakan komunikasi yang selamat, perlindungan data dan pengesahan pengguna. Contohnya, ia boleh digunakan untuk menyulitkan data sensitif sebelum menghantarnya melalui Internet, atau untuk menjana cincang kata laluan selamat untuk pengesahan pengguna.

Mari kita fahami melalui program yang menggunakan perpustakaan Crypto.JS untuk pencincangan dan bukti kerja.

Terdapat dua kelas Block dan Blockchain.

class Block{
   constructor(prev_hashValue, data){
      this.data=data;
      this.hash=this.calculateHash();
      this.prev_hashValue=prev_hashValue;
      this.time_stamp= new Date();
      this.pf_work=0;
   }
}

Kelas blok mempunyai lima atribut -

  • data

    - Ini akan menyimpan data dalam blok.

  • hash

    - Ini akan menyimpan cincangan blok dengan memanggil kaedah calculateHash.

  • prev_hashValue

    - Ini akan menyimpan nilai cincang blok sebelumnya.

  • time_stamp

    - Cap masa akan mengandungi masa blok itu dibuat.

  • pf_work

    - Nombor yang ditambah semasa melombong.

  • Kelas blok mengandungi dua kaedah -
calculateHash(){
   return SHA256(this.pf_work + this.prev_hashValue + this.timestamp + JSON.stringify(this.data)).toString();
}

Fungsi ini akan mengira nilai cincang blok dengan menggabungkan pf_work, prev_hashValue time_stamp dan data dan menghantarnya ke

SHA256

fungsi cincang menggunakan pustaka CryptoJS.

mine(difficulty){
   while(!this.hash.startsWith("0".repeat(difficulty))){
      this.pf_work++;
      this.hash=this.calculateHash();
   }
}
Fungsi ini menggunakan bukti kerja untuk mencari cincang yang bermula dengan bilangan sifar tertentu. Bilangan sifar ditentukan oleh parameter kesukaran yang dihantar kepada kaedah ini. Atribut pf_work ditambah sehingga nilai cincang yang sah ditemui.

class Blockchain{
   constructor(){
      let genesisBlock=new Block("0", {isGenesisBlock: true});
      this.chain=[genesisBlock];
   }
}

rantai

- Ini ialah susunan objek Blok yang membentuk rantaian blok. Kelas blockchain mempunyai dua kaedah -

addNewBlock(data){
   let lastBlock=this.chain[this.chain.length-1];
   let newBlock=new Block(lastBlock.hash, data);
   newBlock.mine(2); //find a hash for new block
   this.chain.push(newBlock);
}

Kaedah ini mencipta objek Blok baharu dengan data yang diluluskan sebagai parameter dan lombong yang digunakan untuk mencari nilai cincang yang sah dan menambahkannya pada tatasusunan rantai.

isValid_hash(){
      for(let i=1; i<this.chain.length; i++){
      const currentBlock=this.chain[i];
      const previousBlock=this.chain[i-1];
      if(currentBlock.hash!=currentBlock.calculateHash()) return false;
      if(currentBlock.prev_hashValue!=previousBlock.hash) return false;
      }
      return true;
}

Kaedah ini menyemak kesahihan rantaian blok dengan melelaran setiap blok dalam tatasusunan rantai dan mengesahkan bahawa sifat cincangnya sepadan dengan nilai cincang yang dikira.

let blockchain=new Blockchain();
blockchain.addNewBlock({
   from: "joe",
   to:"Juhi",
   amount: 100,
});
blockchain.addNewBlock({
   from: "martin",
   to: "Genny",
   amount: 150,
});

Di sini objek akan dibuat menggunakan dua blok, yang akan mempunyai sifat kelas blockchain.

Pelaksanaan ini boleh digunakan sebagai titik permulaan untuk membina aplikasi blockchain yang lebih kompleks yang memerlukan penyimpanan data yang selamat dan tidak berubah. Tetapi perlu diingatkan bahawa ini hanyalah pelaksanaan asas, dan sistem blockchain yang berfungsi sepenuhnya juga memerlukan banyak fungsi tambahan, seperti pengesahan transaksi, mekanisme konsensus, dan langkah keselamatan.

Contoh: Kod lengkap

blockchain.js

const SHA256 = require('crypto-js/sha256');
class Block{
   constructor(prev_hashValue, data){
      this.data=data;
      this.hash=this.calculateHash();
      this.prev_hashValue=prev_hashValue;
      this.time_stamp= new Date();
      this.pf_work=0;
   }

   calculateHash(){
      return SHA256(this.pf_work + this.prev_hashValue + this.time_stamp + JSON.stringify(this.data)).toString();
   }

   mine(difficulty){
      while(!this.hash.startsWith("0".repeat(difficulty))){
         this.pf_work++;
         this.hash=this.calculateHash();
      }
   }
}

class Blockchain{
   constructor(){
      let genesisBlock=new Block("0", {isGenesisBlock: true});
      this.chain=[genesisBlock];
   }

   addNewBlock(data){
      let lastBlock=this.chain[this.chain.length-1];
      let newBlock=new Block(lastBlock.hash, data);
      newBlock.mine(2); //find a hash for new block
      this.chain.push(newBlock);
   }

   isValid_hash(){
      for(let i=1; i<this.chain.length; i++){
         const currentBlock=this.chain[i];
         const previousBlock=this.chain[i-1];
         if(currentBlock.hash!=currentBlock.calculateHash()) return false;
         if(currentBlock.prev_hashValue!=previousBlock.hash) return false;
      }
      return true;
   }
}
//test
let blockchain=new Blockchain();

blockchain.addNewBlock({
   from: "joe",
   to:"Juhi",
   amount: 100,
});

blockchain.addNewBlock({
   from: "martin",
   to: "Genny",
   amount: 150,
});

console.log(blockchain);
console.log("Blockchain is valid: "+blockchain.isValid_hash());
Untuk menyusun atur cara ini, anda mesti memasang node.js. Gunakan artikel ini (Node.js - Persediaan Persekitaran) untuk memasang Node.js. Kemudian gunakan arahan berikut untuk memasang pustaka crypto.js.

npm install crypto-js

Kemudian susun fail program JavaScript. Di sini, nama fail ialah blockchain.

node blockchain.js

OUTPUT

Atas ialah kandungan terperinci Bagaimana untuk menilai blockchain yang dilaksanakan dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:tutorialspoint.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam