HardBirch

Java实现MD5加密解密类

时间:09-07-19 栏目:iOS移动应用开发技术 作者:张飞不张,文采横飞 评论:14 点击: 5,579 次

Java实现MD5加密以及解密类,附带测试类,具体见代码。

MD5加密解密类——MyMD5Util,代码如下:

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.Arrays;

public class MyMD5Util {

private static final String HEX_NUMS_STR="0123456789ABCDEF";
private static final Integer SALT_LENGTH = 12;

/**
* 将16进制字符串转换成字节数组
* @param hex
* @return
*/
public static byte[] hexStringToByte(String hex) {
int len = (hex.length() / 2);
byte[] result = new byte[len];
char[] hexChars = hex.toCharArray();
for (int i = 0; i < len; i++) {
int pos = i * 2;
result[i] = (byte) (HEX_NUMS_STR.indexOf(hexChars[pos]) << 4
| HEX_NUMS_STR.indexOf(hexChars[pos + 1]));
}
return result;
}

/**
* 将指定byte数组转换成16进制字符串
* @param b
* @return
*/
public static String byteToHexString(byte[] b) {
StringBuffer hexString = new StringBuffer();
for (int i = 0; i < b.length; i++) {
String hex = Integer.toHexString(b[i] & 0xFF);
if (hex.length() == 1) {
hex = '0' + hex;
}
hexString.append(hex.toUpperCase());
}
return hexString.toString();
}

/**
* 验证口令是否合法
* @param password
* @param passwordInDb
* @return
* @throws NoSuchAlgorithmException
* @throws UnsupportedEncodingException
*/
public static boolean validPassword(String password, String passwordInDb)
throws NoSuchAlgorithmException, UnsupportedEncodingException {
//将16进制字符串格式口令转换成字节数组
byte[] pwdInDb = hexStringToByte(passwordInDb);
//声明盐变量
byte[] salt = new byte[SALT_LENGTH];
//将盐从数据库中保存的口令字节数组中提取出来
System.arraycopy(pwdInDb, 0, salt, 0, SALT_LENGTH);
//创建消息摘要对象
MessageDigest md = MessageDigest.getInstance("MD5");
//将盐数据传入消息摘要对象
md.update(salt);
//将口令的数据传给消息摘要对象
md.update(password.getBytes("UTF-8"));
//生成输入口令的消息摘要
byte[] digest = md.digest();
//声明一个保存数据库中口令消息摘要的变量
byte[] digestInDb = new byte[pwdInDb.length - SALT_LENGTH];
//取得数据库中口令的消息摘要
System.arraycopy(pwdInDb, SALT_LENGTH, digestInDb, 0, digestInDb.length);
//比较根据输入口令生成的消息摘要和数据库中消息摘要是否相同
if (Arrays.equals(digest, digestInDb)) {
//口令正确返回口令匹配消息
return true;
} else {
//口令不正确返回口令不匹配消息
return false;
}
}

/**
* 获得加密后的16进制形式口令
* @param password
* @return
* @throws NoSuchAlgorithmException
* @throws UnsupportedEncodingException
*/
public static String getEncryptedPwd(String password)
throws NoSuchAlgorithmException, UnsupportedEncodingException {
//声明加密后的口令数组变量
byte[] pwd = null;
//随机数生成器
SecureRandom random = new SecureRandom();
//声明盐数组变量
byte[] salt = new byte[SALT_LENGTH];
//将随机数放入盐变量中
random.nextBytes(salt);

//声明消息摘要对象
MessageDigest md = null;
//创建消息摘要
md = MessageDigest.getInstance("MD5");
//将盐数据传入消息摘要对象
md.update(salt);
//将口令的数据传给消息摘要对象
md.update(password.getBytes("UTF-8"));
//获得消息摘要的字节数组
byte[] digest = md.digest();

//因为要在口令的字节数组中存放盐,所以加上盐的字节长度
pwd = new byte[digest.length + SALT_LENGTH];
//将盐的字节拷贝到生成的加密口令字节数组的前12个字节,以便在验证口令时取出盐
System.arraycopy(salt, 0, pwd, 0, SALT_LENGTH);
//将消息摘要拷贝到加密口令字节数组从第13个字节开始的字节
System.arraycopy(digest, 0, pwd, SALT_LENGTH, digest.length);
//将字节数组格式加密后的口令转化为16进制字符串格式的口令
return byteToHexString(pwd);
}
}

测试类——Client,代码如下:

import java.io.UnsupportedEncodingException;
import java.security.NoSuchAlgorithmException;
import java.util.HashMap;
import java.util.Map;

public class Client {
private static Map users = new HashMap();

public static void main(String[] args){
String userName = "zyg";
String password = "123";
registerUser(userName,password);

userName = "changong";
password = "456";
registerUser(userName,password);

String loginUserId = "zyg";
String pwd = "1232";
try {
if(loginValid(loginUserId,pwd)){
System.out.println("欢迎登陆!!!");
}else{
System.out.println("口令错误,请重新输入!!!");
}
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

/**
* 注册用户
*
* @param userName
* @param password
*/
public static void registerUser(String userName,String password){
String encryptedPwd = null;
try {
encryptedPwd = MyMD5Util.getEncryptedPwd(password);

users.put(userName, encryptedPwd);

} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

/**
* 验证登陆
*
* @param userName
* @param password
* @return
* @throws UnsupportedEncodingException
* @throws NoSuchAlgorithmException
*/
public static boolean loginValid(String userName,String password)
throws NoSuchAlgorithmException, UnsupportedEncodingException{
String pwdInDb = (String)users.get(userName);
if(null!=pwdInDb){ // 该用户存在
return MyMD5Util.validPassword(password, pwdInDb);
}else{
System.out.println("不存在该用户!!!");
return false;
}
}
}

声明: 本文由( 张飞不张,文采横飞 )原创编译,转载请保留链接: Java实现MD5加密解密类

Java实现MD5加密解密类:目前有14 条留言

  1. 14楼
    lfl11111:

    正好是我要的

    2009-08-21 17:04 [回复]
  2. 13楼
    rodane_13:

    为什么运行后出现报警
    java.lang.NoSuchMethodError: main
    Exception in thread &quot;main&quot;

    (ps:我是初学者)

    2009-10-27 16:34 [回复]
  3. 12楼
    M_ChangGong:

    我又试了一下,创建java工程-&gt;创建包-&gt;复制-&gt;粘贴-&gt;执行 没任何问题!

    2009-10-28 17:40 [回复]
  4. 11楼
    匿名用户:

    明明只有+密功能,为啥叫加密解密类?[e02]

    2010-01-23 17:24 [回复]
  5. 10楼
    匿名用户:

    [e01].写的很好。注释也详细。

    2010-06-07 18:35 [回复]
  6. 并没有解密的部分吧!!

    2010-06-15 19:28 [回复]
  7. 同样的字符串为什么加密效果不一样

    2010-07-12 18:50 [回复]
  8. 没有解密部分

    2010-08-06 10:50 [回复]
  9. 6楼
    jblxmn:

    同上 无解密[e07][e02]

    2010-08-09 09:55 [回复]
  10. 5楼
    aibang:

    楼主 MD5能解密吗 好像还不能解密吧

    2010-09-27 11:01 [回复]
  11. 代码不完成啊!

    2010-09-28 13:52 [回复]
  12. 楼主你的MD5加密是多少位的?生成的结果是56位的?正规的是应该是32位的吧。再有你对对同一个字符串加密的结果怎么还不一样?比如对“123”进行加密应该是“202CB962AC59075B964B07152D234B70”。是不是我对MD5理解有问题?

    2010-11-27 11:19 [回复]
  13. 板凳
    wfm0105:

    刚刚上的项目恰好用到

    2011-04-21 16:31 [回复]
  14. 沙发
    Clowind:

    MD5不是不可逆的加密方式吗,怎么可逆了?还有,对同一个字符串加密无论多少次得到的结果应该都是一样的。

    2011-10-05 11:03 [回复]

发表评论


QQ群互动

Linux系统与内核学习群:194051772

WP建站技术学习交流群:194062106

魔豆之路QR

魔豆的Linux内核之路

魔豆的Linux内核之路

优秀工程师当看优秀书籍

优秀程序员,要看优秀书!

赞助商广告

友荐云推荐