加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

使用Javascript实现简单的小型区块链

发布时间:2019-04-12 12:41:36 所属栏目:优化 来源:TiMiGerry
导读:副标题#e# 区块链概念 狭义:区块链是一种按照时间顺序将数据区块以顺序相连的方式组合成的一种链式数据结构,并以密码方式保证的不可篡改和不可伪造的分布式账本。 一、挖矿(产生新区块) 首先,区块链是由每一个区块联系而形成的,在产生新区块之前必须

在区块链中,进行记录转账交易的时候是需要一个加密的算法,把所有的信息进行加密之后再push到新区块中的data中,从而完成一笔新交易的记录。以BTC为例,BTC的加密算法是使用elliptic这个加密算法,elliptic是一个非对称性的加密算法,非对称的加密算法的特点就是,私钥是惟一的,只有拥有者才可以和他私钥对应的公钥进行校验 。 nodejs也有对应的库在github上搜索elliptic即可。

  1. {  
  2.   "privateKey": "34a425df3eb1f22fb6cb74b0e7298b16ffd7f3fb",  
  3.   "publicKey": "ac208623a38d2906b090dbcf3a09378dfe79b77bf39c2b753ef98ea94fe08dc3995a1bd05c917"  

上面是一个生成好的密钥对格式,仅作为展示,我删减了一部分长度。

使用银行卡进行转账交易的时候,会有一个转出的账号和一个转入的账号,在区块链中的记账也会有这个账号,这个账号就是上面使用生成的密钥对中的公钥,公钥就是地址,或者说公钥代表的就是自己的钱包。

校验的方法,首先使用字段“from”,“to”,“amount”的参数进行sign签名,然后在每次挖矿(记账)的时候,则使用verify(),通过前面的三个参数,和sig进行校验

  1. verify(type,data){  
  2.     swtich(type){  
  3.         case 'sign':  
  4.             const bufferMsg = Buffer.from(`${data.from}-${data.to}-${data.amount}`)  
  5.             let signature = Buffer.from(keypair.sign(bufferMsg).toDER()).toString('hex')  
  6.                this.signature =  signature  
  7.         break;  
  8.         case 'verify':  
  9.              const keypairTemp = ec.keyFromPublic(pub, 'hex')  
  10.                 const bufferMsg = Buffer.from(`${data.from}-${data.to}-${data.amount}`)  
  11.              this.keypair = keypairTemp.verify(bufferMsg, sig)  
  12.         break;  
  13.         default;  
  14.     }  

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!