学期末做项目需要MD5加密用户密码,在网上找了很多资料,经过修改、加注释,现在把源码贴上来。
- package org.liushang.util;
-
-
-
-
import java.io.UnsupportedEncodingException;
-
-
import java.security.MessageDigest;
-
-
import java.security.NoSuchAlgorithmException;
-
-
-
-
/**
-
-
* 32位MD5加密,验证
-
-
* @author liushang
-
-
*
-
-
*/
-
-
public class MD5 {
-
-
-
-
/**
-
-
* 将指定的字符串用MD5加密
-
-
* @param originstr 需要加密的字符串
-
-
* @return 加密后的字符串
-
-
*/
-
-
public String ecodeByMD5(String originstr){
-
-
String result = null;
-
-
char hexDigits[] = {//用来将字节转换成 16 进制表示的字符
-
-
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
-
-
if(originstr != null){
-
-
try {
-
-
//返回实现指定摘要算法的 MessageDigest 对象
-
-
MessageDigest md = MessageDigest.getInstance("MD5");
-
-
-
-
//使用utf-8编码将originstr字符串编码并保存到source字节数组
-
-
byte[] source = originstr.getBytes("utf-8");
-
-
//使用指定的 byte 数组更新摘要
-
-
md.update(source);
-
-
//通过执行诸如填充之类的最终操作完成哈希计算,结果是一个128位的长整数
-
-
byte[] tmp = md.digest();
-
-
//用16进制数表示需要32位
-
-
char[] str = new char[32];
-
-
for(int i=0,j=0; i < 16; i++){
-
-
//j表示转换结果中对应的字符位置
-
-
//从第一个字节开始,对 MD5 的每一个字节
-
-
//转换成 16 进制字符
-
-
byte b = tmp[i];
-
-
//取字节中高 4 位的数字转换
-
-
//无符号右移运算符>>> ,它总是在左边补0
-
-
//0x代表它后面的是十六进制的数字. f转换成十进制就是15
-
-
str[j++] = hexDigits[b>>>4 & 0xf];
-
-
// 取字节中低 4 位的数字转换
-
-
str[j++] = hexDigits[b&0xf];
-
-
}
-
-
result = new String(str);//结果转换成字符串用于返回
-
-
} catch (NoSuchAlgorithmException e) {
-
-
//当请求特定的加密算法而它在该环境中不可用时抛出此异常
-
-
e.printStackTrace();
-
-
} catch (UnsupportedEncodingException e) {
-
-
//不支持字符编码异常
-
-
e.printStackTrace();
-
-
}
-
-
}
-
-
return result;
-
-
}
-
-
-
-
//使用MD5检查密码
-
-
public boolean checkPWD(String typPWD, String relPWD){
-
-
if(ecodeByMD5(typPWD).equals(ecodeByMD5(relPWD))){
-
-
return true;
-
-
}
-
-
return false;
-
-
}
-
-
}
其实java的MD5算法就算你瞪着眼睛看也搞不明白,如果想深究其原理就必须弄懂MD5的底层实现。
阅读(8903) | 评论(7) | 转发(2) |