Java实现常用加密算法 —— SHA256

系列文章目录

汇总:Java实现常用加密算法汇总(建议收藏)

第一章:Java实现常用加密算法 —— MD5


文章目录

系列文章目录

前言

二、实现方式

1.Java标准库

2.Apache工具包

三、测试

四、FAQ

总结


前言

在数据安全领域,SHA-256算法展现出了其独特的价值。通过比较数据的SHA-256哈希值,我们可以快速验证数据的完整性和真实性,而无需查看文件具体内容。这一特性使得SHA-256在文件校验、密码存储、数字签名等多个方面发挥着重要作用。本篇主要介绍SHA-256算法在Java(JDK1.8)中如何实现,借助Java标准库或第三方库,非原始实现,较为基础。


一、SHA-256是什么?

SHA-256算法是一种广泛使用的密码学哈希函数,‌它能够将任意长度的数据转换为固定长度的256位哈希值。‌这种算法以其安全性、‌唯一性和固定长度输出的特点,‌在密码学领域占据了重要的地位。SHA-256算法的设计旨在提供一种安全的方式来验证数据的完整性和来源。‌它通过接收任意长度的输入数据,‌生成一个固定长度的256位哈希值,‌这个哈希值可以作为数据的"指纹"。‌由于SHA-256算法的单向性和抗碰撞性,‌使得它成为了一种理想的密码学工具,‌用于确保数据的机密性、‌完整性和身份验证。‌

—— 百度AI

二、实现方式

Java标准库和第三方组件,本质上都是一样的,如果你是正式项目,那最好使用Java标准库自行实现,这样可以省去修复第三方组件开源漏洞的烦恼,特别是银行等对数据安全有严格标准的公司,其次选择Spring的工具包,毕竟现在Java很难不跟Spring扯上关系,最后选择Apache等开源组件;如果你只为方便,那没有争论,谁好用就用谁。

1.Java标准库

代码如下(示例):

public class EncryptUtils {
    /**
     * SHA256,安全散列算法(Secure Hash Algorithm 256-bit),一种被广泛使用的密码散列函数,可以产生出一个固定长度的散列值。用于确保信息传输完整一致。
     * <p>
     * 输入:待加密的字符串
     * 输出:256位(16字节)或64个16进制字符(常用)
     * 应用:密码管理、数字签名、文件完整性校验
     * 安全性:★★☆☆☆
     *
     * @param plainString 明文
     * @return cipherString 密文
     */
    public static String sha256(String plainString) {
        String cipherString = null;
        try {
            // 获取实例(SHA-512同理)
            MessageDigest messageDigest = MessageDigest.getInstance("SHA-256");
            // 计算摘要
            byte[] cipherBytes = messageDigest.digest(plainString.getBytes(StandardCharsets.UTF_8));
            // 输出为16进制字符串
            StringBuilder sb = new StringBuilder();
            for (byte b : cipherBytes) {
                sb.append(String.format("%02x", b));
            }
            cipherString = sb.toString();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return cipherString;
    }
}

2.Apache工具包

导入Maven依赖(建议使用最新版本)

<dependency>
    <groupId>commons-codec</groupId>
    <artifactId>commons-codec</artifactId>
    <version>1.15</version>
</dependency>

代码如下(示例):

import org.apache.commons.codec.digest.DigestUtils;
 
public class EncryptUtils {
    /**
     * SHA256,安全散列算法(Secure Hash Algorithm 256-bit),一种被广泛使用的密码散列函数,可以产生出一个固定长度的散列值。用于确保信息传输完整一致。
     * <p>
     * 输入:待加密的字符串
     * 输出:256位(16字节)或64个16进制字符(常用)
     * 应用:密码管理、数字签名、文件完整性校验
     * 安全性:★★☆☆☆
     *
     * @param plainString 明文
     * @return cipherString 密文
     */
    public static String sha256(String plainString) {
        return DigestUtils.sha256Hex(plainString.getBytes(StandardCharsets.UTF_8));
    }
}

三、测试

我在这里随机找了一个在线md5加密的某网站做对比,如下:

代码如下(示例):

public class EncryptUtils {
    ...
 
    public static void main(String[] args) {
        String plainString = "hello world, hello java!";
        String sha256 = sha256(plainString);
        System.out.println("加密前: " + plainString);
        System.out.println("加密后: " + sha256);    
    }
}

代码运行截图:

网站运行截图:


四、FAQ

Q、如何校验文件完整性?

A:无论是Java标准库还是Spring或Apache,计算摘要时,实际入参是byte[],只需要使用流读取文件获取文件的字节数组再计算摘要即可。


总结

以上就是今天要讲的内容,本文仅仅简单介绍了MD5加密算法在Java中的实现方式,各个加密算法的对比及总结请见本文系列文章汇总篇,水平有限,难免出错,仅供参考,不喜勿喷,感谢!更多内容请百度和ChatGPT!

  • 13
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值