亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

200行代碼實現blockchain 區塊鏈實例詳解

2024-05-06 16:43:04
字體:
來源:轉載
供稿:網友

了解blockchain的概念很簡單(區塊鏈,交易鏈塊):它是分布式的(即不是放置在同一臺機器上,不同的網絡設備上的)數據庫支持主辦記錄日益增長的名單。但是,這也是容易混淆blockchain與我們試圖幫他解決了目標 - 在人們心中的那一刻,這個詞是相當強烈的交易,合同或智能cryptocurrency的概念有關。

只有在這里blockchain - 是不是一回事比特幣,并理解鏈塊的基本知識比它似乎更容易,尤其是在,它是基于源代碼的情況下。在本文中,我們提出了建立與在JavaScript中200行代碼的簡單模型。這個項目,我們稱之為NaiveChain的源代碼,可以在GitHub上找到。第1部分和第2部分:如果您需要刷上它的功能,使用我們的備忘單,我們將使用標準的ECMAScript 6。
塊結構

第一步 - 確定應包含塊的元素。為簡單起見,我們只包括最必要的:先前塊的指數(指數),時間標記(時間戳),數據(數據),散列和散列,要錄制,以保持電路的結構完整性。

200行代碼實現區塊鏈,區塊鏈,blockchain

class Block {   constructor(index, previousHash, timestamp, data, hash) {     this.index = index;     this.previousHash = previousHash.toString();     this.timestamp = timestamp;     this.data = data;     this.hash = hash.toString();   } }

 散列單元

哈希塊需要保持數據的完整性。在我們的例子,這適用于算法SHA-256。這種類型的散列是不相關的開采,因為在這種情況下,我們并沒有用表現證明實施保護。

var calculateHash = (index, previousHash, timestamp, data) => {   return CryptoJS.SHA256(index + previousHash + timestamp + data).toString(); }; 

產生單元

要生成塊,我們需要知道前一個塊的哈希,使我們在結構已經確定了元素的其余部分。數據由最終用戶提供。

var generateNextBlock = (blockData) => {   var previousBlock = getLatestBlock();   var nextIndex = previousBlock.index + 1;   var nextTimestamp = new Date().getTime() / 1000;   var nextHash = calculateHash(nextIndex, previousBlock.hash, nextTimestamp, blockData);   return new Block(nextIndex, previousBlock.hash, nextTimestamp, blockData, nextHash); }; 

存儲單元

使用blockchain 存儲陣列。第一個塊總是硬編碼“創世紀塊”。

var getGenesisBlock = () => {   return new Block(0, "0", 1465154705, "my genesis block!!", "816534932c2b7154836da6afc367695e6337db8a921823784c14378abed4f7d7"); }; var blockchain = [getGenesisBlock()]; 

確認塊的完整性

我們必須始終能夠確認單元或電路的完整性。尤其是當你從其他單位新的單位,必須決定是否接受它們。

var isValidNewBlock = (newBlock, previousBlock) => {   if (previousBlock.index + 1 !== newBlock.index) {     console.log('invalid index');     return false;   } else if (previousBlock.hash !== newBlock.previousHash) {     console.log('invalid previoushash');     return false;   } else if (calculateHashForBlock(newBlock) !== newBlock.hash) {     console.log(typeof (newBlock.hash) + ' ' + typeof calculateHashForBlock(newBlock));     console.log('invalid hash: ' + calculateHashForBlock(newBlock) + ' ' + newBlock.hash);     return false;   }   return true; }; 

選擇鏈最長的

在電路塊的順序必須被明確指定,但是在發生沖突的情況下(例如,兩個節點同時在同一生成的塊和相同數量),我們選擇電路,其中包含的塊的數量較多。

var replaceChain = (newBlocks) => {   if (isValidChain(newBlocks) && newBlocks.length > blockchain.length) {     console.log('Received blockchain is valid. Replacing current blockchain with received blockchain');     blockchain = newBlocks;     broadcast(responseLatestMsg());   } else {     console.log('Received blockchain invalid');   } }; 

消息到其它網絡節點

該網站的一個組成部分 - 與其他節點的數據交換。下列規則用于維護網絡同步:
當一個節點產生新的單元,它會報告給網絡;
當本機連接到新的盛宴,他要求有關最后生成的塊信息;
當一個節點正面臨著一個塊,其中有一個指標比他還大,他增加了一個塊到電路或請求的完整鏈條的信息。
自動搜索同齡人不執行,所有環節都手動添加。

單元的控制

用戶應該能夠以某種方式控制節點,通過將HTTP服務器解決。當與節點相互作用有以下功能:
打印所有單元的列表;
創建用戶生成內容的新單元;
打印列表,或添加的節日。
互動的最直接的方式 - 通過卷曲:

200行代碼實現區塊鏈,區塊鏈,blockchain

一個節點上的所有塊#名單

curl http://localhost:3001/blocks

架構

值得注意的是,該網站是指兩個Web服務器:HTTP進行用戶控制的裝置和向所述的WebSocket HTTP來安裝節點之間的P2P連接。

如下為js 200行代碼

<span style="font-family:Arial, Helvetica, sans-serif;">'use strict';</span> var CryptoJS = require("crypto-js"); var express = require("express"); var bodyParser = require('body-parser'); var WebSocket = require("ws"); var http_port = process.env.HTTP_PORT || 3001; var p2p_port = process.env.P2P_PORT || 6001; var initialPeers = process.env.PEERS ? process.env.PEERS.split(',') : []; class Block {   constructor(index, previousHash, timestamp, data, hash) {     this.index = index;     this.previousHash = previousHash.toString();     this.timestamp = timestamp;     this.data = data;     this.hash = hash.toString();   } } var sockets = []; var MessageType = {   QUERY_LATEST: 0,   QUERY_ALL: 1,   RESPONSE_BLOCKCHAIN: 2 }; var getGenesisBlock = () => {   return new Block(0, "0", 1465154705, "my genesis block!!", "816534932c2b7154836da6afc367695e6337db8a921823784c14378abed4f7d7"); }; var blockchain = [getGenesisBlock()]; var initHttpServer = () => {   var app = express();   app.use(bodyParser.json());   app.get('/blocks', (req, res) => res.send(JSON.stringify(blockchain)));   app.post('/mineBlock', (req, res) => {     var newBlock = generateNextBlock(req.body.data);     addBlock(newBlock);     broadcast(responseLatestMsg());     console.log('block added: ' + JSON.stringify(newBlock));     res.send();   });   app.get('/peers', (req, res) => {     res.send(sockets.map(s => s._socket.remoteAddress + ':' + s._socket.remotePort));   });   app.post('/addPeer', (req, res) => {     connectToPeers([req.body.peer]);     res.send();   });   app.listen(http_port, () => console.log('Listening http on port: ' + http_port)); }; var initP2PServer = () => {   var server = new WebSocket.Server({port: p2p_port});   server.on('connection', ws => initConnection(ws));   console.log('listening websocket p2p port on: ' + p2p_port); }; var initConnection = (ws) => {   sockets.push(ws);   initMessageHandler(ws);   initErrorHandler(ws);   write(ws, queryChainLengthMsg()); }; var initMessageHandler = (ws) => {   ws.on('message', (data) => {     var message = JSON.parse(data);     console.log('Received message' + JSON.stringify(message));     switch (message.type) {       case MessageType.QUERY_LATEST:         write(ws, responseLatestMsg());         break;       case MessageType.QUERY_ALL:         write(ws, responseChainMsg());         break;       case MessageType.RESPONSE_BLOCKCHAIN:         handleBlockchainResponse(message);         break;     }   }); }; var initErrorHandler = (ws) => {   var closeConnection = (ws) => {     console.log('connection failed to peer: ' + ws.url);     sockets.splice(sockets.indexOf(ws), 1);   };   ws.on('close', () => closeConnection(ws));   ws.on('error', () => closeConnection(ws)); }; var generateNextBlock = (blockData) => {   var previousBlock = getLatestBlock();   var nextIndex = previousBlock.index + 1;   var nextTimestamp = new Date().getTime() / 1000;   var nextHash = calculateHash(nextIndex, previousBlock.hash, nextTimestamp, blockData);   return new Block(nextIndex, previousBlock.hash, nextTimestamp, blockData, nextHash); }; var calculateHashForBlock = (block) => {   return calculateHash(block.index, block.previousHash, block.timestamp, block.data); }; var calculateHash = (index, previousHash, timestamp, data) => {   return CryptoJS.SHA256(index + previousHash + timestamp + data).toString(); }; var addBlock = (newBlock) => {   if (isValidNewBlock(newBlock, getLatestBlock())) {     blockchain.push(newBlock);   } }; var isValidNewBlock = (newBlock, previousBlock) => {   if (previousBlock.index + 1 !== newBlock.index) {     console.log('invalid index');     return false;   } else if (previousBlock.hash !== newBlock.previousHash) {     console.log('invalid previoushash');     return false;   } else if (calculateHashForBlock(newBlock) !== newBlock.hash) {     console.log(typeof (newBlock.hash) + ' ' + typeof calculateHashForBlock(newBlock));     console.log('invalid hash: ' + calculateHashForBlock(newBlock) + ' ' + newBlock.hash);     return false;   }   return true; }; var connectToPeers = (newPeers) => {   newPeers.forEach((peer) => {     var ws = new WebSocket(peer);     ws.on('open', () => initConnection(ws));     ws.on('error', () => {       console.log('connection failed')     });   }); }; var handleBlockchainResponse = (message) => {   var receivedBlocks = JSON.parse(message.data).sort((b1, b2) => (b1.index - b2.index));   var latestBlockReceived = receivedBlocks[receivedBlocks.length - 1];   var latestBlockHeld = getLatestBlock();   if (latestBlockReceived.index > latestBlockHeld.index) {     console.log('blockchain possibly behind. We got: ' + latestBlockHeld.index + ' Peer got: ' + latestBlockReceived.index);     if (latestBlockHeld.hash === latestBlockReceived.previousHash) {       console.log("We can append the received block to our chain");       blockchain.push(latestBlockReceived);       broadcast(responseLatestMsg());     } else if (receivedBlocks.length === 1) {       console.log("We have to query the chain from our peer");       broadcast(queryAllMsg());     } else {       console.log("Received blockchain is longer than current blockchain");       replaceChain(receivedBlocks);     }   } else {     console.log('received blockchain is not longer than received blockchain. Do nothing');   } }; var replaceChain = (newBlocks) => {   if (isValidChain(newBlocks) && newBlocks.length > blockchain.length) {     console.log('Received blockchain is valid. Replacing current blockchain with received blockchain');     blockchain = newBlocks;     broadcast(responseLatestMsg());   } else {     console.log('Received blockchain invalid');   } }; var isValidChain = (blockchainToValidate) => {   if (JSON.stringify(blockchainToValidate[0]) !== JSON.stringify(getGenesisBlock())) {     return false;   }   var tempBlocks = [blockchainToValidate[0]];   for (var i = 1; i < blockchainToValidate.length; i++) {     if (isValidNewBlock(blockchainToValidate[i], tempBlocks[i - 1])) {       tempBlocks.push(blockchainToValidate[i]);     } else {       return false;     }   }   return true; }; var getLatestBlock = () => blockchain[blockchain.length - 1]; var queryChainLengthMsg = () => ({'type': MessageType.QUERY_LATEST}); var queryAllMsg = () => ({'type': MessageType.QUERY_ALL}); var responseChainMsg = () =>({   'type': MessageType.RESPONSE_BLOCKCHAIN, 'data': JSON.stringify(blockchain) }); var responseLatestMsg = () => ({   'type': MessageType.RESPONSE_BLOCKCHAIN,   'data': JSON.stringify([getLatestBlock()]) }); var write = (ws, message) => ws.send(JSON.stringify(message)); var broadcast = (message) => sockets.forEach(socket => write(socket, message)); connectToPeers(initialPeers); initHttpServer(); initP2PServer(); 

總結

以上所述是小編給大家介紹的200行代碼實現blockchain 區塊鏈實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久99精品久久久久久青青91| 欧美成人午夜影院| 欧美孕妇毛茸茸xxxx| 久久精品国产免费观看| 欧美黑人xxxx| 国语自产精品视频在线看一大j8| 亚洲人成欧美中文字幕| 国产精品69精品一区二区三区| 中文字幕欧美亚洲| 一区二区三区精品99久久| 欧美人与物videos| 国内精品久久久久久久| 国产精品激情自拍| 亚洲精品电影网在线观看| 大伊人狠狠躁夜夜躁av一区| 久久久亚洲福利精品午夜| 91在线无精精品一区二区| 国产精品久在线观看| 亚洲女人天堂视频| 亚洲色无码播放| 91精品国产777在线观看| 国产日韩欧美中文在线播放| 国产精品久久久久av免费| 精品久久久久久久久中文字幕| 亚洲日本aⅴ片在线观看香蕉| 美女黄色丝袜一区| 欧美国产日产韩国视频| 久久久国产精品x99av| 亚洲淫片在线视频| 欧美极品少妇xxxxⅹ免费视频| 日韩黄色av网站| 亚洲天堂网在线观看| 麻豆国产精品va在线观看不卡| 欧美性高潮床叫视频| 一区二区三区视频在线| 亚洲高清福利视频| 欧美激情综合亚洲一二区| 日韩不卡在线观看| 亚洲一区二区在线播放| 亚洲乱码一区二区| 欧美性猛交xxxx免费看| 欧美孕妇毛茸茸xxxx| 亚洲一区www| 国产精品美女无圣光视频| 日韩免费观看在线观看| 欧洲精品在线视频| 国产欧美va欧美va香蕉在| 亚洲精品不卡在线| 日韩av中文字幕在线| 精品国产一区二区三区久久| 欧美精品在线免费| 色噜噜狠狠色综合网图区| 庆余年2免费日韩剧观看大牛| 久久久久国产精品www| 曰本色欧美视频在线| 日韩专区在线播放| 2019日本中文字幕| 国产一区二区三区在线视频| 欧美影院成年免费版| 国产精品福利网站| 精品小视频在线| 国产一区二区三区久久精品| 精品久久久久久久久久久久久| 国产精品久久久久aaaa九色| 国内精品美女av在线播放| 97超碰色婷婷| 最新国产精品拍自在线播放| 久久久国产成人精品| 欧美午夜宅男影院在线观看| 欧美激情视频播放| 国产精品一区二区电影| 国模私拍视频一区| 日韩精品在线观看视频| 日韩一区av在线| 午夜精品久久久久久99热| 91中文在线观看| 亚洲第一级黄色片| 欧美视频在线免费看| 亚洲欧美在线看| 亚洲国产天堂久久综合网| 97在线观看视频国产| 91精品国产综合久久男男| 中文字幕精品久久久久| 亚洲电影免费观看高清完整版在线| 亚洲国产精品免费| 亚洲欧洲在线观看| 国产婷婷成人久久av免费高清| 欧美日韩中文字幕| 91精品国产免费久久久久久| …久久精品99久久香蕉国产| 成人在线一区二区| 亚洲精品一区二区三区不| 中文字幕免费精品一区| 亚洲大胆美女视频| 国产有码在线一区二区视频| 国产主播在线一区| 欧美最顶级的aⅴ艳星| 奇米四色中文综合久久| 综合国产在线视频| 国产精品www色诱视频| 日韩在线一区二区三区免费视频| 91久久久久久久久久久久久| 国产日韩欧美在线观看| 福利一区福利二区微拍刺激| 中文字幕精品久久久久| 国产精品私拍pans大尺度在线| 成人精品一区二区三区| 亚洲资源在线看| 国产精品三级久久久久久电影| 亚洲精品久久视频| 亚洲r级在线观看| 午夜精品国产精品大乳美女| 色悠悠久久88| 国产精品日韩av| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产小视频国产精品| 日本中文字幕久久看| 97视频在线观看亚洲| 亚洲另类激情图| 性夜试看影院91社区| 午夜精品一区二区三区在线视频| 国产不卡精品视男人的天堂| 日韩免费高清在线观看| 亚洲精品免费在线视频| 亚洲精品v天堂中文字幕| 92裸体在线视频网站| 亚洲欧美日韩综合| 91老司机在线| 日韩精品福利在线| 日韩精品免费电影| 欧美一级大片在线免费观看| 久久成人18免费网站| 精品欧美aⅴ在线网站| 91tv亚洲精品香蕉国产一区7ujn| 国产精品v日韩精品| 亚洲第一中文字幕| 在线视频精品一| 欧美日韩免费在线观看| 97在线免费观看| xvideos国产精品| 精品福利在线视频| 亚洲色图第一页| 国产视频福利一区| 国产一区二区三区视频| 欧美中文字幕在线观看| 欧美视频在线免费| 国产日产久久高清欧美一区| 欧美夜福利tv在线| 亚洲国产精彩中文乱码av在线播放| 福利视频第一区| 成人av在线亚洲| 国产精品视频永久免费播放| 久久精品国产久精国产一老狼| 亚洲性视频网址| 欧美日韩在线看| 亚洲国产日韩精品在线| 亚洲国产天堂久久国产91| yellow中文字幕久久| 日韩大片免费观看视频播放| 久久精品99久久久久久久久| 日韩电影中文字幕| 欧美大片在线看免费观看| 国产精品激情av电影在线观看| 欧美亚洲伦理www|