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

embedded/2025/2/1 16:52:52/

SHAUtil工具

java">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值生成工具

java">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.ppmy.cn/embedded/158682.html

相关文章

智慧小区物业管理系统助力提升社区运营效率与居民生活品质

内容概要 智慧小区物业管理系统是现代社区管理的重要组成部分&#xff0c;它以提高社区运营效率和居民生活品质为核心目标&#xff0c;通过多种技术手段的应用&#xff0c;实现了信息透明和资源的高效利用。这个系统不仅仅是一个简单的物业管理工具&#xff0c;更是一个多功能…

KVM虚拟化

1. 虚拟化技术 虚拟化&#xff0c;通过模拟计算机的硬件&#xff0c;实现同一台计算机上同时运行多个操作系统 2. 虚拟化软件的差别 qemu 软件模拟全虚拟化&#xff0c;速度慢&#xff0c;兼容性好&#xff01; xen&#xff08;半&#xff09; …

算法随笔_30: 去除重复字母

上一篇:算法随笔_29:最大宽度坡_方法3-CSDN博客 题目描述如下: 给你一个字符串 s &#xff0c;请你去除字符串中重复的字母&#xff0c;使得每个字母只出现一次。需保证 返回结果的字典序最小&#xff08;要求不能打乱其他字符的相对位置&#xff09;。 示例 1&#xff1a; …

PHP中配置 variables_order详解

variables_order 是 PHP 配置文件 php.ini 中的一项配置指令&#xff0c;决定了 PHP 在处理请求时&#xff0c;哪些类型的变量将被注册到全局变量空间&#xff08;如 $GLOBALS&#xff09;中&#xff0c;以及这些变量的顺序。理解和正确配置 variables_order 对于开发和维护安全…

基于springboot+vue的流浪动物救助系统的设计与实现

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

深度学习篇---深度学习框架

文章目录 前言第一部分&#xff1a;框架简介1. PyTorch简介特点动态计算图易于上手强大的社区支持与Python的集成度高 核心组件 2. TensorFlow简介特点静态计算图跨平台强大的生态系统Keras集成 核心组件 3. PaddlePaddle简介特点易于使用高性能工业级应用丰富的预训练模型 核心…

用一个例子详细说明python单例模式

单例模式是一种设计模式&#xff0c;它确保一个类只有一个实例&#xff0c;并提供一个全局访问点来访问该实例。这在需要控制资源&#xff08;如数据库连接、文件系统等&#xff09;的访问时非常有用。 下面是一个使用Python实现单例模式的例子&#xff1a; class Singleton:…

一文读懂fgc之cms

一文读懂 fgc之cms-实战篇 1. 前言 线上应用运行过程中可能会出现内存使用率较高&#xff0c;甚至达到95仍然不触发fgc的情况&#xff0c;存在内存打满风险&#xff0c;持续触发fgc回收&#xff1b;或者内存占用率较低时触发了fgc&#xff0c;导致某些接口tp99&#xff0c;tp…