MD5算法了解(JAVA实现)

MD5算法:虽然已经被破解,但任然广泛应用于各个领域中

如文件校验:当我们下载文件时为了保证文件的安全性,我们可以在其网站上找到对应的md5值进行校验,如果md5值不一致,也就是说文件被人动过(一般都是挂马了),所以文件校验领域应用十分广泛。

如数字签名证书,当我们访问12306时,经常会出现该网站证书已过期,问你是否继续访问,在一般情况下是自己的电脑时间设置不正确,但除开这种情况也就是你访问的网站不是同一个网站。

还有就是当作密钥,这个在我们生活中还算比较的常用,因为md5算法开源,我们可以免费使用,而且在没有密钥的情况下破解成本较高,在一般情况下我们都还是采用md5算法

package com.jack.md5;

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

public class MD5Util {
	public static final String MD5(String src) {
		//char[] hexDigits = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };

		byte[] input = src.getBytes();

		try {
			MessageDigest digest = MessageDigest.getInstance("MD5");
			//官方说法更新摘要
			//个人理解:就是找到要加密的字符串,放置到update()中等待digest()方法进行产出
			//就像是在机器的两头:一头的将原材料放进去,一头是产品的输出
			//获取输入
			digest.update(input);
			//获得产出
			input = digest.digest();
			
			//下面就是进行十六进制的转换
			int length = input.length;
			StringBuffer strBuff = new StringBuffer();
			for(int i = 0;i<length;i++)
			{
				//将字符转变成对应的ASSIC值
				int val = ((int)input[i])&0xff;
				//转变成对应的值后小于4位
				if(val<16)
				{
					strBuff.append("0");
				}
				strBuff.append(Integer.toHexString(val));
//				strBuff.append(hexDigits[val%16]);
			}
			
			return strBuff.toString();
		} catch (NoSuchAlgorithmException e) {
			e.printStackTrace();
		}

		return src;
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值