blockchain 区块链200行代码 在JavaScript实现的一个简单的例子

这篇博客介绍了如何使用JavaScript实现一个简单的区块链,包括块结构、散列单元、产生单元、存储单元、确认块完整性的过程,并提供了相关代码示例。此外,还涉及到选择最长链的规则以及消息在网络节点间的传递。最后,作者呼吁读者支持其老师的人工智能教程。
摘要由CSDN通过智能技术生成

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

                了解blockchain的概念很简单(区块链,交易链块):它是分布式的(即不是放置在同一台机器上,不同的网络设备上的)数据库支持主办记录日益增长的名单。但是,这也是容易混淆blockchain与我们试图帮他解决了目标 - 在人们心中的那一刻,这个词是相当强烈的交易,合同或智能cryptocurrency的概念有关。
只有在这里blockchain - 是不是一回事比特币,并理解链块的基本知识比它似乎更容易,尤其是在,它是基于源代码的情况下。在本文中,我们提出了建立与在JavaScript中200行代码的简单模型。这个项目,我们称之为NaiveChain的源代码,可以在GitHub上找到。 第1部分和第2部分:如果您需要刷上它的功能,使用我们的备忘单,我们将使用标准的ECMAScript 6。

块结构

第一步 - 确定应包含块的元素。为简单起见,我们只包括最必要的:先前块的指数(指数),时间标记(时间戳),数据(数据),散列和散列,要录制,以保持电路的结构完整性。


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(newBlo
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值