引言

区块链技术是一项比人工智能更具革命性的技术,人工智能只是提高了人类的生产力,而区块链则将改变人类社会的生产关系,它将会颠覆我们人类社会现有的协作方式。了解和掌握区块链相关知识和技术,是我们每位开发人员必须要去做的事情,这样我们才能把握住这波时代趋势的红利。

本文将基于Java语言构建简化版的blockchain,来实现数字货币。

创建区块

区块链是由包含交易信息的区块从后向前有序链接起来的数据结构。区块被从后向前有序地链接在这个链条里,每个区块都指向前一个区块。以比特币为例,每个区块主要包含如下信息字段:

区块大小:用字节表示的区块数据大小

区块头:组成区块头的几个字段

区块头hash值

父区块头hash值

时间戳:区块产生的近似时间

Merkle根:该区块中交易的merkle树根的哈希值

难度目标:该区块工作量证明算法的难度目标

Nonce:用于工作量证明算法的计数器

交易计数器:交易的数量

交易:记录在区块里的交易信息

区块数据结构

在这里,我们主要是为了实现最简单的区块链结构,仅仅包含以下几个信息字段:

/**

* 区块

*

* @author wangwei

* @date 2018/02/02

*/

@Data

public class Block {

/**

* 区块hash值

*/

private String hash;

/**

* 前一个区块的hash值

*/

private String previousHash;

/**

* 区块数据

*/

private String data;

/**

* 区块创建时间(单位:秒)

*/

private long timeStamp;

public Block() {

}

public Block(String hash, String previousHash, String data, long timeStamp) {

this();

this.hash = hash;

this.previousHash = previousHash;

this.data = data;

this.timeStamp = timeStamp;

}

}

区块Hash值计算

加密Hash值,一个通过SHA256算法对区块头进行二次哈希计算而得到的数字指纹。Hash值用于确保blockchain的安全。Hash计算是计算敏感的操作,即使在高性能电脑也需要花费一段时间来完成计算(这也就是为什么人们购买高性能GPU进行比特币挖矿的原因)。blockchain架构设计有意使Hash计算变得困难,这样做是为了加大新增一个block的难度,进而防止block在增加后被随意修改。

/**

*

创建新区块

*

* @param previousHash

* @param data

* @return

*/

public static Block newBlock(String previousHash, String data) {

Block block = new Block("", previousHash, data.getBytes(), Instant.now().getEpochSecond());

block.setHash();

return block;

}

/**

* 计算区块Hash

*

* 注意:在准备区块数据时,一定要从原始数据类型转化为byte[],不能直接从字符串进行转换

*

* @return

*/

private void setHash() {

byte[] prevBlockHashBytes = {};

if (StringUtils.isNoneBlank(this.getPrevBlockHash())) {

prevBlockHashBytes = new BigInteger(this.getPrevBlockHash(), 16).toByteArray();

}

byte[] headers = ByteUtils.merge(

prevBlockHashBytes,

this.getData().getBytes(),

ByteUtils.toBytes(this.getTimeStamp()));

this.setHash(DigestUtils.sha256Hex(headers));

}

创建区块链

区块链本质上是一种有序、反向链接链表的数据结构。这意味着,block按照插入的顺序存放,同时每个block都保存指向上一个block的链接。这种结构保证可以快速获取最新插入的block同时获取它的hash值。这种结构保证可以快速获取最新插入的block同时(高效地)获取它的hash值。

区块链数据结构

/**

*

区块链

*

* @author wangwei

* @date 2018/02/02

*/

public class Blockchain {

@Getter

private List blockList;

public Blockchain(List blockList) {

this.blockList = blockList;

}

}

添加区块

新增一个添加区块链的方法

/**

*

添加区块

*

* @param data 数据

*/

public void addBlock(String data) {

Block previousBlock = blockList.get(blockList.size() - 1);

this.addBlock(Block.newBlock(previousBlock.getHash(), data));

}

/**

*

添加区块

*

* @param block 区块

*/

public void addBlock(Block block) {

this.blockList.add(block);

}

创世区块

在添加区块之前,区块链必须有个创世区块,在Block中新增创世区块方法:

/**

*

创建创世区块

*

* @return

*/

public static Block newGenesisBlock() {

return Block.newBlock("", "Genesis Block");

}

创建区块链

再在Blockchain中新增创建区块链的方法:

/**

*

创建区块链

*

* @return

*/

public static Blockchain newBlockchain() {

List blocks = new LinkedList<>();

blocks.add(Block.newGenesisBlock());

return new Blockchain(blocks);

}

测试运行

/**

* 测试

*

* @author wangwei

* @date 2018/02/05

*/

public class BlockchainTest {

public static void main(String[] args) {

Blockchain blockchain = Blockchain.newBlockchain();

blockchain.addBlock("Send 1 BTC to Ivan");

blockchain.addBlock("Send 2 more BTC to Ivan");

for (Block block : blockchain.getBlockList()) {

System.out.println("Prev. hash: " + block.getPreviousHash());

System.out.println("Data: " + block.getData());

System.out.println("Hash: " + block.getHash());

System.out.println();

}

}

}

/**

* 输出如下信息:

*/

Prev. hash:

Data: Genesis Block

Hash: 4492cb9d396a9a52e7ff17ef3782f022ddcdc7b2c276bc6dd3d448b0655eb3d4

Prev. hash: 4492cb9d396a9a52e7ff17ef3782f022ddcdc7b2c276bc6dd3d448b0655eb3d4

Data: Send 1 BTC to Ivan

Hash: cd716d59d98ad673035ab7035ece751718ea9842944a4743c298bebc0fe24c04

Prev. hash: cd716d59d98ad673035ab7035ece751718ea9842944a4743c298bebc0fe24c04

Data: Send 2 more BTC to Ivan

Hash: 42f78d6a86f88aa9b5b10e468494dfd1b3f558a9fb74a01eb348c2cbfc5d000a

总结

我们构建了一个非常简单的区块链原型:它只是一个块的数组,每个块都与前一个块有连接。 实际的区块链要复杂得多。

缺少交易信息:我们的区块链还没有任何交易信息。

缺少工作量证明:我们的生产区块非常简单快捷,实际的区块链中,生产一个区块需要进行大量的计算。

缺少共识机制:区块链是一个非单一决策者的分布式数据库。 因此,一个新的区块必须得到网络的其他参与者的确认和批

在以后的文章中,我们将介绍这些功能。

资料

区块链java语言,基于Java语言构建区块链(一)—— 基本原型相关推荐

  1. R语言基于自定义函数构建xgboost模型并使用LIME解释器进行模型预测结果解释:基于训练数据以及模型构建LIME解释器解释一个iris数据样本的预测结果、LIME解释器进行模型预测结果解释并可视化

    R语言基于自定义函数构建xgboost模型并使用LIME解释器进行模型预测结果解释:基于训练数据以及模型构建LIME解释器解释一个iris数据样本的预测结果.LIME解释器进行模型预测结果解释并可视化 ...

  2. R语言基于自定义函数构建xgboost模型并使用LIME解释器进行模型预测结果解释:基于训练数据以及模型构建LIME解释器解释多个iris数据样本的预测结果、使用LIME解释器进行模型预测结果解释

    R语言基于自定义函数构建xgboost模型并使用LIME解释器进行模型预测结果解释:基于训练数据以及模型构建LIME解释器解释多个iris数据样本的预测结果.使用LIME解释器进行模型预测结果解释并可 ...

  3. R语言基于lm模型构建线性回归模型(蟋蟀的鸣叫声与温度的关系)、计算回归模型的RMSE指标、计算回归模型的R方指标(R-squared)

    R语言基于lm模型构建线性回归模型(蟋蟀的鸣叫声与温度的关系).计算回归模型的RMSE指标.计算回归模型的R方指标(R-squared) 目录

  4. java kdj_基于Java语言开发的个性化股票分析技术随机指数[KDJ].doc

    基于Java语言开发的个性化股票分析技术:随机指数(KDJ) KDJ指标又叫随机指标,是由乔治·蓝恩博士(GeorgeLane)最早提出的,是一种相当新颖.实用的技术分析指标,它起先用于期货市场的分析 ...

  5. java kdj_基于java语言开发的个性化股票分析技术:随机指数(kdj).doc

    基于java语言开发的个性化股票分析技术:随机指数(kdj).doc 还剩 17页未读, 继续阅读 下载文档到电脑,马上远离加班熬夜! 亲,很抱歉,此页已超出免费预览范围啦! 如果喜欢就下载吧,价低环 ...

  6. java毕业设计——基于Java+Bootstrap+Mysql的电影评论网站设计与实现(毕业论文+程序源码)——电影评论网站

    基于Java+Bootstrap+Mysql的电影评论网站设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于Java+Bootstrap+Mysql的电影评论网站设计与实现,文章末尾附有本毕 ...

  7. java毕业设计——基于java+图像处理技术的医学图像处理系统设计与实现(毕业论文+程序源码)——医学图像处理系统

    基于java+图像处理技术的医学图像处理系统设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于java+图像处理技术的医学图像处理系统设计与实现,文章末尾附有本毕业设计的论文和源码下载地址哦 ...

  8. java毕业设计—— 基于java+JSP+SSH的婴幼儿产品销售系统设计与实现(毕业论文+程序源码)——婴幼儿产品销售系统

    基于java+JSP+SSH的婴幼儿产品销售系统设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于java+JSP+SSH的婴幼儿产品销售系统设计与实现,文章末尾附有本毕业设计的论文和源码下 ...

  9. java毕业设计——基于java+Servlet+jsp的网上花店销售系统设计与实现(毕业论文+程序源码)——网上花店销售系统

    基于java+Servlet+jsp的网上花店销售系统设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于java+Servlet+jsp的网上花店销售系统设计与实现,文章末尾附有本毕业设计的 ...

最新文章

  1. Java PriorityQueue实现大顶堆
  2. 除了数据,生活中还有这些......
  3. 【数字信号处理】序列傅里叶变换 ( 基本序列的傅里叶变换 | 求 a^nu(n) 的傅里叶变换 )
  4. 学生如何提高专业英文阅读能力--施一公教授
  5. Android开发之动态添加控件
  6. 十问十答 Ms-PL 许可证
  7. python训练词库_在Python中训练NGramModel
  8. [BZOJ3093][Fdu校赛2012] A Famous Game(不等概率)
  9. 1268:【例9.12】完全背包问题
  10. 5.2.4 std::atomic:指针运算
  11. Android MediaRecorder调用AudioRecord流程
  12. iOS FMDB有返回结果集和无返回结果集
  13. 三菱FX3U生产方案 FX3U源代码+PCB文件全套生产方案 基于STM32F10的FX3U源码, 可直接使用GXworks2软件
  14. U盘安装完kali后内存变小的言diao(无图)博客
  15. win10-两电脑通过一根网线连接
  16. FutureTask.get(timeOut)执行原理浅析
  17. Typical of the grassland dwellers of the continent is the American antelope
  18. esp8266 NVS_FLASH 应用指南
  19. ppt学习06——排版
  20. 行为识别框架Slowfast解读

热门文章

  1. 03-body标签中相关标签
  2. iOS中转义后的html标签如何还原
  3. PHP通过SMTP实现发送邮件_包括附件
  4. Travel(HDU 4284状压dp)
  5. Zxing 扫描码的ios简化版搭建过程
  6. ASP.NET与JS交互
  7. 【编程语言】正则表达式快速上手
  8. selenium定位不到元素的原因。
  9. 如何利用图像识别、语音识别、文本挖掘做好鉴黄?
  10. 从零开始学 Java - Spring MVC 实现跨域资源 CORS 请求