<1>MessageDigest基础

  MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。

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

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

  

1、public static MessageDigest getInstance(String algorithm) throws NoSuchAlgorithmException
   返回实现指定摘要算法的 MessageDigest 对象。
     algorithm - 所请求算法的名称

2、public static MessageDigest getInstance(String algorithm,String provider)throws NoSuchAlgorithmException,NoSuchProviderException
  返回实现指定摘要算法的 MessageDigest 对象。
    algorithm - 所请求算法的名称
    provider - 提供者的名称。

3、public void update(byte[] input)
  使用指定的 byte 数组更新摘要。 

4、public byte[] digest()
  通过执行诸如填充之类的最终操作完成哈希计算。在调用此方法之后,摘要被重置。

5、public static boolean isEqual(byte[] digesta, byte[] digestb)
比较两个摘要的相等性。做简单的字节比较。

注意:Provider可以通过 Java.security.Security.getProviders() 方法获取已注册提供者列表。比较常用的有“SUN”

SUN提供的常用的算法名称有:

          MD2
          MD5
                        SHA-1
                        SHA-256
                        SHA-384
                        SHA-512

举例说明:

  /**
     * 将一个字符串进行MD5算法,获取摘要
     * @param str
     * @return
     */
    public static String md5Hex(String str){
        byte[] data = str.getBytes();
        try {
            //获取指定算法的MessageDigest对象
            MessageDigest digest = MessageDigest.getInstance("MD5");
            //更新摘要
            digest.update(data);
            //获取经过摘要算法后的摘要字节数组
            byte[] messageDigest = digest.digest();
            StringBuffer hexString = new StringBuffer();
            //将经摘要算法的字节数组装换成十六进制的字符串
            for(byte b : messageDigest){
                String hex = Integer.toHexString(b & 0xff);
                if(hex.length()<2){ //长度小于2,转换时需加上一个0,构成两位格式
                    hexString.append(0);
                }
                hexString.append(hex);
            }
            return hexString.toString();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return "";
    }

<二> MessageDigest高级应用

(1)MessageDigest对文件进行摘要计算

  /**
     * 获取文件信息摘要计算
     * @param in
     * @return
     * @throws IOException
     * @throws NoSuchAlgorithmException
     */
    public static String fileResume(InputStream in) throws IOException, NoSuchAlgorithmException{
        MessageDigest digest = MessageDigest.getInstance("MD5");

        byte[] buf = new byte[1024];
        int len = 0;
        while((len = in.read(buf))!=-1){
            //每次更新缓冲中的字节摘要
            digest.update(buf,0,len);
        }
        byte[] data = digest.digest();
        //获取经过摘要算法后的摘要字节数组
        byte[] messageDigest = digest.digest();
        StringBuffer hexString = new StringBuffer();
        //将经摘要算法的字节数组装换成十六进制的字符串
        for(byte b : messageDigest){
            String hex = Integer.toHexString(b & 0xff);
            if(hex.length()<2){ //长度小于2,转换时需加上一个0,构成两位格式
                hexString.append(0);
            }
            hexString.append(hex);
        }
        return hexString.toString();
    }

(2)第三方jar包

  commons-codec 提供了便捷的MD5工具类, 可以简化消息摘要计算:

  引入jar包后,直接调用

    DigestUtil.DigestUtils.md5Hex(String str)  获取字符串的MD5信息摘要

    DigestUtils.sha1Hex(String str)  获取字符串的SHA-1信息摘要

    DigestUtils.md5Hex(InputStream in) 获取输入流的MD5信息摘要

<三>MD5原理

MessageDigest消息摘要的更多相关文章

  1. 使用JDK自带的MessageDigest计算消息摘要

    使用JDK自带的MessageDigest计算消息摘要 上代码 /** * 使用JDK自带MessageDigest */ public class MessageDigestUtils { /** ...

  2. 消息摘要java.security.MessageDigest

    这是一种与消息认证码结合使用以确保消息完整性的技术.主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4.MD5.SHA-1,jdk1.5对 ...

  3. Java 消息摘要 散列 MD5 SHA

    package xxx.common.util; import java.math.BigInteger; import java.security.MessageDigest; import jav ...

  4. [Java 安全]消息摘要与数字签名

    消息摘要 算法简述 定义 它是一个唯一对应一个消息或文本的固定长度的值,它由一个单向Hash加密函数对消息进行作用而产生.如果消息在途中改变了,则接收者通过对收到消息的新产生的摘要与原摘要比较,就可知 ...

  5. HMAC加密的消息摘要码

    HMAC(Hash Message Authentication Code)哈希消息授权码,它在消息摘要算法(例如MD5,SHA系列算法)的基础上,使用密钥对消息摘要进行加密.它相当于一个马甲,内里可 ...

  6. java中的数据加密1 消息摘要

    消息摘要(Message Digest) 又称为数字摘要(Digital Digest).它是一个唯一对应一个消息或文本的固定长度的值,它由一个单向Hash加密函数对消息进行作用而产生.如果消息在途中 ...

  7. 基于HTTP在互联网传输敏感数据的消息摘要、签名与加密方案

    基于HTTP在互联网传输敏感数据的消息摘要.签名与加密方案 博客分类: 信息安全 Java 签名加密AESMD5HTTPS  一.关键词 HTTP,HTTPS,AES,SHA-1,MD5,消息摘要,数 ...

  8. 消息摘要技术(MD5)

    1.使用消息摘要技术对密码加密 数据库存储的是经过消息摘要技术加密之后的信息, 避免保存密码明文,提升了系统安全性 必要性说明: 如果存储明文密码,数据库系统管理员和攻破系统的黑客是可以拿到你的所有信 ...

  9. JDK自带方法实现消息摘要运算

    啊,有点小注释,懒得介绍了,就贴个代码吧,大意理解就可以了. package jdbc.pro.lin; import java.security.InvalidKeyException; impor ...

随机推荐

  1. Android性能优化之内存优化练习

    练习题目地址:https://github.com/lzyzsd/MemoryBugs 分析及优化过程如下: 问题1 静态变量引用activity 使用神器LeakCanary检查内存泄露问题 从图中 ...

  2. 如何修复AppScan漏洞

    [AppScan]修复漏洞一:启用不安全的HTTP方法 (中) 漏洞背景:      “启用了不安全的 HTTP 方法”属于“中”危漏洞.漏洞描述是:根据APPSCAN的报告,APPSCAN通过OPT ...

  3. 蓝牙BLE ATT剖析(一)

    一.概述 The attribute protocol allows a device referred to as the server to expose a set of attributes ...

  4. composer很慢修改镜像

    有两种方式启用本镜像服务: 系统全局配置: 即将配置信息添加到 Composer 的全局配置文件 config.json 中.见“例1” 单个项目配置: 将配置信息添加到某个项目的 composer. ...

  5. Project Euler 76:Counting summations

    题目链接 原题: It is possible to write five as a sum in exactly six different ways: 4 + 13 + 23 + 1 + 12 + ...

  6. 将EmEditor加入到鼠标右键菜单

    在清理系统的时候,无意中将EmEditor的鼠标右键功能给清理掉了,在EmEditor的配置中又没有找到如何加入到鼠标右键菜单的方法,只好使用导入注册表功能了,以下的代码,拷贝到记事本中,保存为EmE ...

  7. .NET自带缓存机制实例

    using System;using System.Web;using System.Web.Caching;using System.Collections.Generic;using System ...

  8. VMware虚拟机误删除vmdk文件后如何恢复?

    故障描述: Dell R710系列服务器(用于VMware虚拟主机),Dell MD 3200系列存储(用于存放虚拟机文件),VMware ESXi 5.5版本,因意外断电,导致某台虚拟机不能正常启动 ...

  9. 20165235 祁瑛 2018-4 《Java程序设计》第九周学习总结

    20165235 祁瑛 2018-4 <Java程序设计>第九周学习总结 教材学习内容总结 URL类 UR类是java.net包中的一个重要类,使用URL创建的对象的应用程序称作称作客户端 ...

  10. codeforces278A

    Circle Line CodeForces - 278A 郑州地铁的圆线有n个车站. 我们知道所有邻近站点之间的距离: d[1]是第1站和第2站之间的距离;d[2]是第2站和第3站之间的距离;… d ...