zoukankan      html  css  js  c++  java
  • java使用MD5加密

    一、主要使用MessageDigest类(java.security包下

    1、首先,先看下官方文档

    • 此 MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值
    • MessageDigest 对象开始被初始化。该对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。
    • 对于给定数量的更新数据,digest 方法只能被调用一次。在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态

    2、接下来看几个MessageDigest的方法(按照使用顺序介绍

    1. public static MessageDigestgetInstance(String algorithm)
                                       throws NoSuchAlgorithmException
      返回实现指定摘要算法的 MessageDigest 对象。参数algorithm为加密方式,可选MD5、sha...
    2. void
        update(byte[] input)
                使用指定的 byte 数组更新摘要。
    3. 获取摘要字节数组
      public byte[] digest()
    通过执行诸如填充之类的最终操作完成哈希计算。在调用此方法之后,摘要被重置
    返回:
    存放哈希值结果的 byte 数组。

    3、将字节数组转换成16进制字符串

      为什么要将字节数组转换成16进制字符串?

    我们使用digest()方法获得MessageDigest生成的摘要后需要将其转换成String字符串

    Java中无论是汉字还是英文字母都是用Unicode编码来表示的,一个Unicode码是16位,每字节是8位,所以一个Unicode码占两字节。

    但是英文字母比较特殊,源自于8位(1字节)的ASCII码,于是在Unicode码仅使用了低8位(1字节)就可以表示,高8位的话不使用也无所谓。

     

    代码如下:

    String str = "lalalla";
            byte[] resultByteArray;
            try {
                //获取MessageDigest对象
                MessageDigest messageDigest = MessageDigest.getInstance("MD5");
                messageDigest.update(str.getBytes());
                resultByteArray = messageDigest.digest();
                for(Byte content:resultByteArray){
                    System.out.println(content);
                }
                System.out.println(bytesToHexFun2(resultByteArray));
            } catch (NoSuchAlgorithmException e) {
                e.printStackTrace();
            } 

     

     二、byte[]转十六进制String(转载自:http://blog.csdn.net/worm0527/article/details/69939307)

    所谓十六进制String,就是字符串里面的字符都是十六进制形式,因为一个byte是八位,可以用两个十六进制位来表示,因此,byte数组中的每个元素可以转换为两个十六进制形式的char,所以最终的HexString的长度是byte数组长度的两倍

    private static final char[] HEX_CHAR = {'0', '1', '2', '3', '4', '5', 
                '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
    
    
      /**
         * 方法二:
         * byte[] to hex string
         * 
         * @param bytes
         * @return
         */
        public static String bytesToHexFun2(byte[] bytes) {
            char[] buf = new char[bytes.length * 2];
            int index = 0;
            for(byte b : bytes) { // 利用位运算进行转换
                buf[index++] = HEX_CHAR[b >>> 4 & 0xf];//高四位
                buf[index++] = HEX_CHAR[b & 0xf];//低四位
            }
    
            return new String(buf);
        }

    如果是使用MD5得到的摘要进行转换,那么得到的字符串为32位(因为MD5得到的摘要的字节数组的长度为16),这样我们利用二中byte[]转十六进制String的方法将一中生成的字节数组进行转换,即得到我们需要的String类型的MD5加密字符串。

    注意:如果使用new String(byteArray)将获得的字节数组直接转换成String,则会出现乱码

  • 相关阅读:
    JS浅拷贝和深拷贝
    使用阿里云短信服务
    autojs相关的文档地址记录和简单使用
    Linux 根目录所在分区被脏数据占满
    openstack宿主机故障,虚拟实例恢复
    openstack创建vlan网络并配置网络设备
    联想 lenove 3750 M4服务器更改启动项和管理口IP
    ansible常用方法
    Mysql数据库-多实例主从复制-主从故障详解
    Linux 系统优化-workstation实践
  • 原文地址:https://www.cnblogs.com/lige-H/p/7209946.html
Copyright © 2011-2022 走看看