sha256算法是非对称加密,是不可以逆的,但也可以暴力破解
一般对系统的用户表的密码加密,然后对比加密后的字符串是否相等
在线加密网址
http://www.ttmd5.com/hash.php?type=9
package utils;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
* sha256加密工具类
* @author
* @version 1.0
* @date 2021/8/3 10:48
* @since JDK 1.8
public class EncryptSha256Util {
public static void main(String[] args) {
String sha256Str = getSha256Str("123456");
System.out.println(sha256Str);
* sha256加密
* @param str 要加密的字符串
* @return 加密后的字符串
public static String getSha256Str(String str) {
MessageDigest messageDigest;
String encodeStr = "";
try {
messageDigest = MessageDigest.getInstance("SHA-256");
messageDigest.update(str.getBytes(StandardCharsets.UTF_8));
encodeStr = byte2Hex(messageDigest.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
return encodeStr;
* sha256加密 将byte转为16进制
* @param bytes 字节码
* @return 加密后的字符串
private static String byte2Hex(byte[] bytes) {
StringBuilder stringBuilder = new StringBuilder();
String temp;
for (byte aByte : bytes) {
temp = Integer.toHexString(aByte & 0xFF);
if (temp.length() == 1) {
stringBuilder.append("0");
stringBuilder.append(temp);
return stringBuilder.toString();
再告诉大家一个更强大而便捷的加密工具,叫Hutool工具(其实它里面还有很多其他工具,比如日期、字符串等等等等)
Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。
代码如下,它里面有非常多的加密方式和种类
import cn.hutool.crypto.digest.DigestUtil;
public static void main(String[] args) {
String decrypt = DigestUtil.sha256Hex("要加密的字符串");
System.out.println(decrypt);
截图如下,它的sha256加密的入参种类非常多,真的很便捷

需要的pom依赖为
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.5</version>
</dependency>
ava.security.MessageDigest类用于为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。简单点说就是用于生成散列码。信息摘要是安全的单向哈希函数,它接收任意大小的数据,输出固定长度的哈希值。关于信息摘要和散列码请参照《数字证书简介》
MessageDigest 通过其getInstance系列静态函数来进行实例化和初始化。MessageDigest 对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算并返回结果。
上述代码中,我们使用 FileInputStream 以字节流的方式逐块读取文件内容,然后通过 DigestInputStream 将读取的数据传递给 MessageDigest 来计算 SHA256 哈希值。这样可以避免将整个文件加载到内存中,而是通过缓冲区逐块处理文件内容。可以通过流式处理逐块读取文件的内容,并在读取的同时计算 SHA256 哈希值,以避免一次性加载整个文件。Java不需要将整个文件加载到 JVM 内存中才能计算文件的 SHA256 值。
package com.customcode.util;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
* @author Yuyb
* @version 1.0
* 类说明:
* @date 2020/5/28 9:49
public class MeikeSHA256U.
Hutool是一个Java工具包,它提供了许多实用的工具类,包括加密工具。可以使用Hutool的DigestUtil类来进行SHA-256加密。
以下是一个示例代码,演示如何使用Hutool的DigestUtil类进行SHA-256加密:
import cn.hutool.crypto.digest.DigestAlgorithm;
import cn.hutool.crypto.digest.DigestUtil;
public class HutoolSha256Example {