只用120行Java代码写一个自己的区块链
搞定了块的天生,接下来我们必要有函数帮我们判定一个块是否有被改动。搜查 Index 来看这个块是否正确得递增,搜查 PrevHash 与前一个块的 Hash 是否同等,再来通过 calculateHash 搜查当前块的 Hash 值是否正确。通过这几步我们就能写出一个校验函数:
除了校验块以外,我们还会碰着一个题目:两个节点都天生块并添加到各自的链上,那我们应该以谁为准?这里的细节我们留到下一篇文章,这里先让我们记着一个原则:始终选择最长的链。 [block 1] -> [block 2] -> [block 3] -> [block 4] -> [block 5] -> 承认 [block 1] -> [block 2] -> [block 3] -> [block 4] -> 扬弃 凡是来说,更长的链暗示它的数据(状态)是越发新的,以是我们必要一个函数能帮我们将当地的逾期的镣迫椿成最新的链:
到这一步,我们根基就把全部重要的函数完成了。接下来,我们必要一个利便直观的方法来查察我们的链,包罗数据及状态。通过赏识器查察 web 页面大噶?鲱吻合的方法。 Web 处事 我猜你必然对传统的 web 处事及开拓很是认识,以是这部门你必定一看就会。 借助 Spark Web Framework,来完成我们的 web 处事,代码如下:
OK,完成,对,你没看错,就是一个空的main要领,就可以了。 接下来我们界说差异 endpoint 以及对应的 handler。譬喻,对“/”的 GET 哀求我们可以查察整个链,对“/”的 POST 哀求可以建设一个新的块。 GET 哀求的 handler:
为了简化,我们直接以 JSON 名目返回整个链,你可以在赏识器中会见 localhost:4567 可能 127.0.0.1:4567 来查察 POST 哀求的 handler 轻微有些伟大,我们先来界说一下 POST 哀求的 payload:
再看看 handler 的实现:
我们的 POST 哀求体中可以行使上面界说的 payload,好比: {"vac":7500} (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |