当前位置: 首页 > news >正文

基于Hutool的Merkle树hash值生成工具

SHAUtil工具

package com.blockchain.qgy.util;import com.xiaoleilu.hutool.crypto.digest.DigestUtil;
import org.apache.commons.codec.binary.Hex;import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;/**** 生成SHA-256的工具** @author QGY**/
public class SHAUtil {/*** function 利用apache commons-codec的工具类实现SHA-256* @param plainText:明文* @return 密文*/public static String getSHA256BasedMD(String plainText){MessageDigest messageDigest;String encdeStr = "";try {messageDigest = MessageDigest.getInstance("SHA-256");byte[] hash = messageDigest.digest(plainText.getBytes(StandardCharsets.UTF_8));encdeStr = new String(Hex.encodeHex(hash));} catch (Exception e){e.printStackTrace();}return encdeStr;}/*** function 利用Hutool工具类实现SHa-256加密* @param plainText:明文* @return 密文*/public static String sha256BasedHutool(String plainText){return DigestUtil.sha256Hex(plainText);}
}

Merkle树hash值生成工具

package com.blockchain.qgy.util;import java.util.ArrayList;
import java.util.List;
import java.util.Objects;/**** merkle树的对应工具** @author QGY**/
public class MerkleTreeUtil {/*** function 获取根节点的hash值* @param hashList:非根节点的hash值的树状数组* @return 根节点的hash值*/public static String getTreeNodeHash(List<String> hashList){//判断入参if(Objects.isNull(hashList) || hashList.size() == 0) return null;while (hashList.size() != 1) {hashList = getMerkleNodeList(hashList);}//找出根节点return hashList.get(0);}/*** function 根据非根节点将叶子节点的hash值处理成其父亲节点的hash值* @param hashList:非根节点的hash值的树状数组* @return 非根节点的hash值集合(处理后)*/private static List<String> getMerkleNodeList(List<String> hashList) {//判断入参if(Objects.isNull(hashList) || hashList.size() == 0) return hashList;List<String> merkleNodeList = new ArrayList<>();int index = 0;int length = hashList.size();//处理hash值树状数组while (index < length) {//1.获取左孩子节点的hash值String left = hashList.get(index++);//2.获取右孩子节点的hash值String right = "";if (index < length) {right = hashList.get(index++);}//计算左右孩子节点的父亲节点的hash值String currHash = SHAUtil.sha256BasedHutool(left.concat(right));merkleNodeList.add(currHash);}return merkleNodeList;}
}

对Merkle树的简单说明

       Merkle树是一种数据结构,它是一种哈希树的变体。它由计算机科学家Ralph Merkle在1979年提出。Merkle树的主要目的是验证大量数据的完整性。

        Merkle树的构建过程是通过对原始数据块逐层进行哈希计算来完成的。首先,原始数据被分成固定大小的块。然后,每个块都通过一个哈希函数计算出一个固定长度的哈希值。这些哈希值再通过哈希函数再次计算,直到最后只剩下一个哈希值,这个哈希值被称为根哈希。根哈希是Merkle树的根节点。

        Merkle树的特点是它的任何部分数据的一点改变都会导致整个树的根哈希值发生变化。这使得Merkle树非常适合于验证大量数据的完整性。通过比较根哈希值和任意子节点的哈希值,可以快速确定数据是否被篡改。

        Merkle树在许多领域得到了广泛应用,特别是在密码学和区块链中。在密码学中,Merkle树用于验证数字证书的完整性。在区块链中,Merkle树用于验证交易的有效性,以及验证区块的完整性。通过使用Merkle树,可以提高数据的安全性和可靠性。

依赖坐标

<dependency><groupId>com.xiaoleilu</groupId><artifactId>hutool-all</artifactId><version>3.0.9</version>
</dependency>
http://www.lryc.cn/news/529667.html

相关文章:

  • Windows系统本地部署deepseek 更改目录
  • 深度学习篇---数据存储类型
  • 可被electron等调用的Qt截图-录屏工具【源码开放】
  • electron 应用开发实践
  • openssl 生成证书 windows导入证书
  • 程序员学英文之At the Airport Customs
  • 字节iOS面试经验分享:HTTP与网络编程
  • 游戏引擎 Unity - Unity 启动(下载 Unity Editor、生成 Unity Personal Edition 许可证)
  • 前端八股CSS:盒模型、CSS权重、+与~选择器、z-index、水平垂直居中、左侧固定,右侧自适应、三栏均分布局
  • Linux网络 | 网络层IP报文解析、认识网段划分与IP地址
  • 服务器虚拟化实战:架构、技术与最佳实践
  • (leetcode 213 打家劫舍ii)
  • [C语言日寄] <stdio.h> 头文件功能介绍
  • 一文读懂 Faiss:开启高维向量高效检索的大门
  • 【二叉搜索树】
  • R语言统计分析——ggplot2绘图5——拟合光滑曲线
  • 疯狂拆单词01
  • 高效学习方法分享
  • 01.双Android容器解决方案
  • 一文大白话讲清楚webpack进阶——9——ModuleFederation实战
  • Mysql意向锁
  • 输入一行字符,分别统计出其中英文字母,空格,数字和其他字符的个数。
  • AD电路仿真
  • vim 中粘贴内容时提示: -- (insert) VISUAL --
  • Redis_Redission的入门案例、多主案例搭建、分布式锁进行加锁、解锁底层源码解析
  • ZZNUOJ(C/C++)基础练习1021——1030(详解版)
  • 力扣116. 填充每个节点的下一个右侧节点指针
  • 寒武纪MLU370部署deepseek r1
  • Python NumPy(10):NumPy 统计函数
  • Ubuntu下的Doxygen+VScode实现C/C++接口文档自动生成