MD5信息摘要算法
MD5(Message Digest)
- 它是一种哈希算法,不是一种加密算法,任何长度的任意内容都可以用MD5计算出散列值
- 无论字符串还是文件都可以计算MD5值,无论字符串长短,还是文件大或者小,计算出来的MD5值的位数相同
- 不可逆,不可能根据现有的MD5值,计算出原来的字符串是什么
- 不可重复性(理论上可以重复,但是几率很小)
- MD5算法理论上是不可逆的,因此攻击的唯一办法就是碰撞,两个不同的内容生成相同的MD5值,这就是碰撞
- 为何要使用MD5加密?所有的数据库软件都是程序员编写的,只要是软件,必然有bug,一旦bug被屏蔽,就可以窃取用户的密码。而MD5加密是不可逆的,只能加密,不能解密。
-MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。除了MD5以外,其中比较有名的还有sha-1、RIPEMD以及Haval等。
Java中简单的MD5加密类MD5Utils
public class MD5Utils {
/**
* MD5加密
* @param text 需要加密的字符串
* @return 返回加密后的字符串
*/
public static String md5(String text){
MessageDigest digest = null;
try {
//创建加密对象
digest = MessageDigest.getInstance("md5");
//数组 byte[] result -> digest.digest( ); 文本 text.getBytes();
//调用加密对象,加密动作已完成
byte[] result = digest.digest(text.getBytes());
//创建StringBuilder对象 然后建议StringBuffer,安全性高,
//StringBuilder 相较于 StringBuffer 有速度优势;StringBuffer 线程安全
//接下来对加密后的结果进行优化
StringBuffer sb = new StringBuffer();
// result数组,digest.digest ( ); -> text.getBytes();
// for 循环数组byte[] result;
for (byte b:result){
//将数据全部转换为正数
int number = b & 0xff;//也就是255
// 解释:为什么采用b&255
/*
* b:它本来是一个byte类型的数据(1个字节) 255:是一个int类型的数据(4个字节)
* byte类型的数据与int类型的数据进行运算,会自动类型提升为int类型 eg: b: 1001 1100(原始数据)
* 运算时:
* b : 0000 0000 0000 0000 0000 0000 1001 1100
* 255: 0000 0000 0000 0000 0000 0000 1111 1111
* 结果:0000 0000 0000 0000 0000 0000 1001 1100
* 此时的temp是一个int类型的整数
*/
//将所有的数据转换成16进制的形式
String hex = Integer.toHexString(number);
//当正数小于16时,使用Integer.toHexString(number)可能会造成缺少位数
if(number<16&&number>=0){
//手动补上一个“0”
sb.append("0"+hex);
}else {
sb.append(hex);
}
}
return sb.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
//发送异常return空字符串
return "";
}
}
public static void main(String[] args){
String pwd = MD5Utils.md5("abc");
System.out.println(pwd);
}
}
今日推歌
—《荣耀天成》张新成&周昭妍
袖间藏千里江山
蓝绿临摹自华夏的水天
眉间起洛神的微风
吹过清明上河的垂柳和人烟
心间流觞杯盏绕月
盛开成一万段锦绣和诗篇
用一杯茶的时间
想念世界
天上星辰 写出漫天上阙
落音为墨 天成满地画卷
呼吸之间 身为一座宫殿
太和在心 只因心中一愿
家永定
国德胜
天下长安
抬头是天外天