MD5算法了解(JAVA实现)

来源:互联网 发布:德阳儿童学编程 编辑:程序博客网 时间:2024/05/29 13:28

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;}}


0 0
原创粉丝点击