java字符串应用之密码加密与验证
2007-11-24 04:34
435 查看
MD5的全称是Message-Digest Algorithm 5,在20世纪90年代初由MTI的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3、MD4发展而来。MD5将任意长度的“字符串”变换成一个128为的大整数,并且它是一个不可逆的字符串变换算法,也就是说,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始字符串有无穷多个,这有点像不存在反函数的数学函数。
一、关键技术点
1、通过java.Security.MessageDigest的静态方法getInstance创建具有指定算法名称的信息摘要,参数为算法名,传入”MD5“则表示使用MD5算法
2、MessageDigest的digest实例方法使用指定的字节数组对摘要进行最后的更新,然后完成摘要计算,返回存放哈希值结果的字节数组,这个字节数组就是MD5的加密产品。
3、将加密后的字节数组转换成十六进制的字符串,形成最终的密码。
4、当输入字符串经过MD5加密后,得到的字符串与密码一样,则认为密码验证通过。
二、演示实例:
package book.String;
import java.security.MessageDigest;
/** *//**
* 对密码进行加密和验证的程序
* @author joe
*
*/
public class Password ...{
//十六进制下数字到字符的映射数组
private final static String[] hexDigits = ...{"0", "1", "2", "3", "4",
"5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};
/** *//** 把inputString加密 */
public static String createPassword(String inputString)...{
return encodeByMD5(inputString);
}
/** *//**
* 验证输入的密码是否正确
* @param password 真正的密码(加密后的真密码)
* @param inputString 输入的字符串
* @return 验证结果,boolean类型
*/
public static boolean authenticatePassword(String password, String inputString) ...{
if(password.equals(encodeByMD5(inputString))) ...{
return true;
} else ...{
return false;
}
}
/** *//** 对字符串进行MD5加密 */
private static String encodeByMD5(String originString) ...{
if (originString != null) ...{
try...{
//创建具有指定算法名称的信息摘要
MessageDigest md = MessageDigest.getInstance("MD5");
//使用指定的字节数组对摘要进行最后更新,然后完成摘要计算
byte[] results = md.digest(originString.getBytes());
//将得到的字节数组变成字符串返回
String resultString = byteArrayToHexString(results);
return resultString.toUpperCase();
} catch(Exception ex) ...{
ex.printStackTrace();
}
}
return null;
}
/** *//**
* 转换字节数组为十六进制字符串
* @param b 字节数组
* @return 十六进制字符串
*/
private static String byteArrayToHexString(byte[] b) ...{
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++) ...{
resultSb.append(byteToHexString(b[i]));
}
return resultSb.toString();
}
/** *//** 将一个字节转化成十六进制形式的字符串 */
private static String byteToHexString(byte b) ...{
int n = b;
if (n < 0)
n = 256 + n;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
public static void main(String[] args) ...{
String password = Password.createPassword("888888");
System.out.println("对888888用MD5摘要后的字符串:" + password);
String inputString = "8888";
System.out.println("8888与密码匹配?" +
Password.authenticatePassword(password, inputString));
inputString = "888888";
System.out.println("888888与密码匹配?" +
Password.authenticatePassword(password, inputString));
}
}
输出结果:
对888888用MD5摘要后的字符串:21218CCA77804D2BA1922C33E0151105
8888与密码匹配?false
888888与密码匹配?true
一、关键技术点
1、通过java.Security.MessageDigest的静态方法getInstance创建具有指定算法名称的信息摘要,参数为算法名,传入”MD5“则表示使用MD5算法
2、MessageDigest的digest实例方法使用指定的字节数组对摘要进行最后的更新,然后完成摘要计算,返回存放哈希值结果的字节数组,这个字节数组就是MD5的加密产品。
3、将加密后的字节数组转换成十六进制的字符串,形成最终的密码。
4、当输入字符串经过MD5加密后,得到的字符串与密码一样,则认为密码验证通过。
二、演示实例:
package book.String;
import java.security.MessageDigest;
/** *//**
* 对密码进行加密和验证的程序
* @author joe
*
*/
public class Password ...{
//十六进制下数字到字符的映射数组
private final static String[] hexDigits = ...{"0", "1", "2", "3", "4",
"5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};
/** *//** 把inputString加密 */
public static String createPassword(String inputString)...{
return encodeByMD5(inputString);
}
/** *//**
* 验证输入的密码是否正确
* @param password 真正的密码(加密后的真密码)
* @param inputString 输入的字符串
* @return 验证结果,boolean类型
*/
public static boolean authenticatePassword(String password, String inputString) ...{
if(password.equals(encodeByMD5(inputString))) ...{
return true;
} else ...{
return false;
}
}
/** *//** 对字符串进行MD5加密 */
private static String encodeByMD5(String originString) ...{
if (originString != null) ...{
try...{
//创建具有指定算法名称的信息摘要
MessageDigest md = MessageDigest.getInstance("MD5");
//使用指定的字节数组对摘要进行最后更新,然后完成摘要计算
byte[] results = md.digest(originString.getBytes());
//将得到的字节数组变成字符串返回
String resultString = byteArrayToHexString(results);
return resultString.toUpperCase();
} catch(Exception ex) ...{
ex.printStackTrace();
}
}
return null;
}
/** *//**
* 转换字节数组为十六进制字符串
* @param b 字节数组
* @return 十六进制字符串
*/
private static String byteArrayToHexString(byte[] b) ...{
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++) ...{
resultSb.append(byteToHexString(b[i]));
}
return resultSb.toString();
}
/** *//** 将一个字节转化成十六进制形式的字符串 */
private static String byteToHexString(byte b) ...{
int n = b;
if (n < 0)
n = 256 + n;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
public static void main(String[] args) ...{
String password = Password.createPassword("888888");
System.out.println("对888888用MD5摘要后的字符串:" + password);
String inputString = "8888";
System.out.println("8888与密码匹配?" +
Password.authenticatePassword(password, inputString));
inputString = "888888";
System.out.println("888888与密码匹配?" +
Password.authenticatePassword(password, inputString));
}
}
输出结果:
对888888用MD5摘要后的字符串:21218CCA77804D2BA1922C33E0151105
8888与密码匹配?false
888888与密码匹配?true
相关文章推荐
- java中字符串 MD5密码的加密与验证
- java中字符串 MD5密码的加密与验证
- java中字符串 MD5密码的加密与验证
- 对文本框中密码加密,对web.config中字符串的加密,身份验证
- Java的MD5对密码进行加密和验证的类
- java对字符串密码的MD5加密与验证
- java正则表达式应用--验证字符串是否为数字
- Java正则表达式应用--验证字符串是否为数字
- 字符串应用_验证注册账户时用名和密码是否符合要求
- java字符串应用之18位身份证格式验证
- java正则表达式应用--验证字符串是否为数字(转载)
- java 情报加密,密码翻译--的字符串问题
- java 之 根据密码字符串加密示例
- java-对密码进行加密和验证的类
- 应用JAVA进行密码加密的一种算法
- md5密码加密(java)
- java字符串加密解密
- Java 字符串的加密和解密
- 用java编写一个简单的字符串加密解密程序,将字符串分成若干行,实现字符串以一列一列读取,并还原之前输入的字符串。这里实现4行输出。
- Java对字符串异或加密