MessageDigest用法

时间:2022-11-03
本文章向大家介绍MessageDigest用法,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

大家好,又见面了,我是你们的朋友全栈君。

为什么要使用MessageDigest?

某些金融行业用于进行简单的密码加密。例如:需求某银行对数据库账户取款密码加密。为了保护客户信息的安全,客户取款密码只能客户自己知道,银行方面对此加密,加密后数据保存的数据库。此时可以用MessageDigest进行加密,以及后续其他方案再次加密。

MessageDigest 是什么?

java.security.MessageDigest类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA-1或SHA-256 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。

MessageDigest 对象调用getInstance初始化,使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。

对于给定数量的更新数据,digest 方法只能被调用一次。在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态。

  • This MessageDigest class provides applications the functionality of a message digest algorithm, such as SHA-1 or SHA-256. Message digests are secure one-way hash functions that take arbitrary-sized data and output a fixed-length hash value. A MessageDigest object starts out initialized. The data is processed through it using the update methods. At any point reset can be called to reset the digest. Once all the data to be updated has been updated, one of the digest methods should be called to complete the hash computation. The digest method can be called once for a given number of updates. After digest has been called, the MessageDigest object is reset to its initialized state.

代码展示:

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class MessageDigestDemo extends Thread {
    
    
    private static final char[] ch = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };

    public  static void run(String str) {
    
    
        byte[] data = null;
        MessageDigest md;
        try {
    
    
            data = str.getBytes("UTF8");
            //初始化对象
            md = MessageDigest.getInstance("MD5");
            //传送要计算的数据更新操作
            md.update(data);
            //计算的数据生成加密数据
            byte[] resultData = md.digest();
            //测试查看输出
            System.out.println(bytes2HexStr(resultData));
        } catch (NoSuchAlgorithmException e) {
    
    
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (UnsupportedEncodingException e) {
    
    
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

    static String bytes2HexStr(byte[] paramArrayOfByte) {
    
    
        StringBuffer localStringBuffer = new StringBuffer(paramArrayOfByte.length * 2);
        for (int i = 0; i < paramArrayOfByte.length; i++)
        {
    
    
            localStringBuffer.append(ch[(paramArrayOfByte[i] >>> 4 & 0xF)]);
            localStringBuffer.append(ch[(paramArrayOfByte[i] & 0xF)]);
        }
        return localStringBuffer.toString();
    }

    public static void main(String[] args) {
    
    
        String text = "loveuu";
        run(text);
    }
}
测试输出:

c591f3416f45f8146de0839266594731

总结:

使用中大多用工具类进行封装,使用时直接调用run(String str)方法,用来传递所要加密的字符串。

更多MessageDigest 方法使用详见JDK文档。

刚开始写技术文章,许多问题不完善,敬请指导!

PS:
参考JDK_API文档
参考http://blog.sina.com.cn/s/blog_4f36423201000c1e.html文章

转载于:https://www.cnblogs.com/JackXv/p/9371543.html

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/157776.html原文链接:https://javaforall.cn