Java md5加密实现

Java md5加密实现

md5算法是把任意一个字符串经过加密后得到一个16位的byte[]数组,也就是128位bit的串,所以md5值有2^128种可能。
2^128=340282366920938463463374607431768211456,这是非常大的一个数,md5是不可逆的,所以这是我们平时经常用到的一个加密算法,数据库存储的用户密码很多是md5算法加密后的


Java生成md5值代码

package com.lipenglong.tool.encrypt;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

/**
 * md5加密器类
 * <p/>
 * Created by lipenglong on 2017/8/10.
 */
public class MD5Encoder {
    private static final char[] HEX = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};

    /**
     * md5加密算法实现:使用Integer的toHexString()方法
     *
     * @param src 加密字符串
     * @return 加密后的md5串
     */
    public static String encode(String src) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(src.getBytes());
            byte[] bytes = md.digest();
            StringBuffer buf = new StringBuffer();
            for (int i = 0; i < bytes.length; i++) {
                String s = Integer.toHexString(bytes[i] & 0xff);
                if (s.length() == 1) {
                    buf.append("0");
                }
                buf.append(s);
            }
            return buf.toString();
        } catch (NoSuchAlgorithmException e) {
            return null;
        }
    }

    /**
     * md5加密算法实现:定义一个16进制char数组,取每一个byte前后四
     * 位对应的char
     *
     * @param src 加密字符串
     * @return 加密后的md5串
     */
    public static String encode2(String src) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(src.getBytes());
            byte[] bytes = md.digest();
            final int nBytes = bytes.length;
            char[] result = new char[2 * nBytes];
            int j = 0;
            for (int i = 0; i < nBytes; i++) {
                // Char for top 4 bits
                result[j++] = HEX[(0xF0 & bytes[i]) >>> 4];
                // Bottom 4
                result[j++] = HEX[(0x0F & bytes[i])];
            }
            return new String(result);
        } catch (NoSuchAlgorithmException e) {
            return null;
        }
    }
}

md5之后得到16位的byte[]数组,每一个byte转换成2位十六进制数值,所以md5后的String字符串是32位。上面的代码中有两种byte转十六进制的实现:

  • encode()方法使用Integer的toHexString()方法把byte转为十六进制,因为toHexString方法接收的参数为int类型,int是4个字节长度,所以执行byte[i]和0xff的按位于操作截取后8位,得到后8位的十六进制数值,然后判断十六进制值的长度,1位的话前面补个0
  • encode2()方法采用的spring security中的 Md5PasswordEncoder 类的实现方式,定义一个HEX十六进制char[]数组,分别取byte[i]前4位和后四位的十六进制数值
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值