对称加密--MD5算法

MD5 算法底层原理:
简单概括起来,MD5 算法的过程分为四步:处理原文,设置初始值,循环加工,拼接结果。
MD5 是一种哈希算法,用来保证信息的完整性。
就一段信息对应一个哈希值,且不能通过哈希值推出这段信息,而且还需要保证不存在任意两段不相同的信息对应同一个哈希值。不过MD5算法算出来的值也就16个字节(16*8=128,即128位),肯定存在相同的,找到另一个所花时间长短而已。

第一步:处理原文

首先,我们计算出原文长度(bit)对 512 求余的结果,如果不等于 448,就需要填充原文使得原文对 512 求余的结果等于 448。填充的方法是第一位填充 1,其余位填充 0。填充完后,信息的长度就是 512*N+448。

之后,用剩余的位置(512-448=64 位)记录原文的真正长度,把长度的二进制值补在最后。这样处理后的信息长度就是 512*(N+1)。

第二步:设置初始值

MD5 的哈希结果长度为 128 位,按每 32 位分成一组共 4 组。这 4 组结果是由 4 个初始值 A、B、C、D 经过不断演变得到。MD5 的官方实现中,A、B、C、D 的初始值如下(16 进制):

MD5 java实例:


import java.security.MessageDigest;

public class MD5 {
	/**
	 * 把传入的String进行MD5摘要。
	 * 
	 * @param f
	 *            传入的字符串
	 * @return String 返回摘要字符串
	 */
	public static String makMd5Digest(String f) {
		try {
			MessageDigest alg = MessageDigest.getInstance("MD5");
			alg.update(f.getBytes());
			byte[] digest = alg.digest();
			return byte2hex(digest);
		} catch (Exception e) {
			System.out.println(e.toString());
			return "";
		}

	}

	/**
	 * 将byte转换为16进制文本
	 * 
	 * @param b
	 *            byte数组
	 * @return String 转换后的数组
	 */
	private static String byte2hex(byte[] b) {
		String hs = "";
		String stmp = "";
		for (int n = 0; n < b.length; n++) {
			stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
			if (stmp.length() == 1)
				hs = hs + "0" + stmp;
			else
				hs = hs + stmp;
		}
		return hs.toLowerCase();
	}

	public static void main(String[] args) {
		String pwd = MD5.makMd5Digest("666666");
		System.out.println(pwd);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值