MD5属于不可逆加密算法,由密文无法推出原文
用法:
public class MD5 {
public static String encrypt(String data){
char[] hex=new char[]{
'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'
};
byte[] encrypted=null;
MessageDigest messageDigest;
try {
messageDigest = MessageDigest.getInstance("MD5");//获取MD5算法的MessageDigest对象
messageDigest.update(data.getBytes("utf-8"));//更新算法摘要
encrypted=messageDigest.digest();//获得密文
char[] result=new char[encrypted.length*2];
int count=0;
for(int i=0;i<encrypted.length;i++){//转化为16进制
byte k=encrypted[i];
result[count++]=hex[k>>>4&0xf];
result[count++]=hex[k&0xf];
}
return new String(result);
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
md5算法可以用来加密用户密码,保证由密文无法推导出原文密码,但为了防止利用拦截的密文进行验证,可以在加一层加密,加入发送时间再次加密,使此次验证密码只在一定时间内有效,二次加密选择可逆加密算法,如RSA.
对于任意长度的明文,MD5可以产生128位的摘要。