• Java加密1-散列函数


    散列函数非常有用,几乎出现在所有信息安全应用程序中。

    哈希函数是将数字输入值转换为另一个压缩数值的数学函数。 散列函数的输入具有任意长度,但输出始终具有固定长度。

    散列函数返回的值称为message digest或简称hash values 。 下图说明了散列函数。

    Java提供了一个名为MessageDigest的类,它属于java.security包。 此类支持诸如SHA-1,SHA 256,MD5算法之类的算法,以将任意长度的消息转换为消息摘要。

    要将给定邮件转换为邮件摘要,请按照以下步骤进行操作 -

    第1步:创建MessageDigest对象

    MessageDigest类提供了一个名为getInstance()的方法。 此方法接受String变量,该变量指定要使用的算法的名称,并返回实现指定算法的MessageDigest对象。

    使用getInstance()方法创建MessageDigest对象,如下所示。

    MessageDigest md = MessageDigest.getInstance("SHA-256");
    

    第2步:将数据传递给创建的MessageDigest对象

    创建消息摘要对象后,需要将消息/数据传递给它。 您可以使用MessageDigest类的update()方法执行此操作,此方法接受表示消息的字节数组,并将其添加/传递给上面创建的MessageDigest对象。

    md.update(msg.getBytes());
    

    第3步:生成消息摘要

    您可以使用digest()方法生成消息摘要,MessageDigest类此方法计算当前对象的散列函数,并以字节数组的形式返回消息摘要。

    使用摘要方法生成消息摘要。

    byte[] digest = md.digest();
    

    例子 (Example)

    以下是从文件中读取数据并生成消息摘要并打印出来的示例。

    1. import java.security.MessageDigest;
    2. import java.util.Scanner;
    3. public class MessageDigestExample {
    4. public static void main(String args[]) throws Exception{
    5. //Reading data from user
    6. Scanner sc = new Scanner(System.in);
    7. System.out.println("Enter the message");
    8. String message = sc.nextLine();
    9. //Creating the MessageDigest object
    10. MessageDigest md = MessageDigest.getInstance("SHA-256");
    11. //Passing data to the created MessageDigest Object
    12. md.update(message.getBytes());
    13. //Compute the message digest
    14. byte[] digest = md.digest();
    15. System.out.println(digest);
    16. //Converting the byte array in to HexString format
    17. StringBuffer hexString = new StringBuffer();
    18. for (int i = 0;i
    19. hexString.append(Integer.toHexString(0xFF & digest[i]));
    20. }
    21. System.out.println("Hex format : " + hexString.toString());
    22. }
    23. }

    输出 (Output)

    上述程序生成以下输出 -

    1. Enter the message
    2. Hello how are you
    3. [B@55f96302
    4. Hex format: 2953d33828c395aebe8225236ba4e23fa75e6f13bd881b9056a3295cbd64d3
  • 相关阅读:
    WinForm应用实战开发指南 - 教你如何实现表头的全选操作?
    Tarjan 求有向图的强连通分量
    [含毕业设计论文+PPT+源码等]ssm加油服务系统+Java后台管理系统|前后分离VUE
    靠这份业界最强算法及数据结构宝典,我挺进字节跳动
    CentOS系统环境搭建(十八)——CentOS7安装Docker20.10.12和docker compose v2
    信息学奥赛中的STL(标准模板库)--2022.09.30
    Spring之AOP详解
    角点检测与SIFT
    GBASE 8A v953报错集锦23--多 sql 任务并发操作报错 get cluster task id fail
    爬取医药卫生知识服务系统的药品数据——超详细流程
  • 原文地址:https://blog.csdn.net/u011016373/article/details/126117130