package algo;
import java.security.MessageDigest;
/**
* MD5 -- message-digest algorithm 5 (信息-摘要算法)缩写,广泛用于加密和解密技术,常用于文件校验。
* 校验?不管文件多大,经过MD5后都能生成唯一的MD5值。
* 好比现在的ISO校验,都 是MD5校验。怎么用?当然是把ISO经过MD5后产生MD5的值。
* 一般下载linux-ISO的朋友都见过下载链接旁边放着MD5的串。就是用来验证文 件是否一致的。
* @author Administrator
*
*/
public class MD5 {
public static void main(String[] args) {
String str = new String("我是中國人");
System.out.println("原始:" + str);
// 加密
String encryptRes = encryptMD5(str);
System.out.println("加密后:" + encryptRes);
// 解密扫行2次解密方法
String decryptRes = decryptMD5(decryptMD5(str));
System.out.println("解密的:" + decryptRes);
}
private static final String MD5 = "MD5";
// MD5加密 生成32位md5码
public static String encryptMD5(String str) {
try {
if (null == str) {
return null;
}
// 获得MD5摘要算法的 MessageDigest 对象
MessageDigest md5 = MessageDigest.getInstance(MD5);
// 获取字符串
char[] charArray = str.toCharArray();
// 创建和字符串长度一样的byte 数组
byte[] byteArray = new byte[charArray.length];
// 循环从byte数组charArray读取数据,赋值给byte数组byteArray
for (int i = 0; i < charArray.length; i++) {
byteArray[i] = (byte) charArray[i];
}
// 获得密文
byte[] md5Bytes = md5.digest(byteArray);
// 把密文转换成十六进制的字符串形式
StringBuffer hexValue = new StringBuffer();
// 字节数组转换为 十六进制数
for (int i = 0; i < md5Bytes.length; i++) {
int val = ((int) md5Bytes[i]) & 0xff;
if (val < 16) {
hexValue.append("0");
}
hexValue.append(Integer.toHexString(val));
}
return hexValue.toString();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
// MD5解密 执行一次加密,两次解密
public static String decryptMD5(String str) {
if (null == str) {
return null;
}
char[] decryptStr = str.toCharArray();
for (int i = 0; i < decryptStr.length; i++) {
decryptStr[i] = (char) (decryptStr[i] ^ 't');
}
String decryptResult = new String(decryptStr);
return decryptResult;
}
}
import java.security.MessageDigest;
/**
* MD5 -- message-digest algorithm 5 (信息-摘要算法)缩写,广泛用于加密和解密技术,常用于文件校验。
* 校验?不管文件多大,经过MD5后都能生成唯一的MD5值。
* 好比现在的ISO校验,都 是MD5校验。怎么用?当然是把ISO经过MD5后产生MD5的值。
* 一般下载linux-ISO的朋友都见过下载链接旁边放着MD5的串。就是用来验证文 件是否一致的。
* @author Administrator
*
*/
public class MD5 {
public static void main(String[] args) {
String str = new String("我是中國人");
System.out.println("原始:" + str);
// 加密
String encryptRes = encryptMD5(str);
System.out.println("加密后:" + encryptRes);
// 解密扫行2次解密方法
String decryptRes = decryptMD5(decryptMD5(str));
System.out.println("解密的:" + decryptRes);
}
private static final String MD5 = "MD5";
// MD5加密 生成32位md5码
public static String encryptMD5(String str) {
try {
if (null == str) {
return null;
}
// 获得MD5摘要算法的 MessageDigest 对象
MessageDigest md5 = MessageDigest.getInstance(MD5);
// 获取字符串
char[] charArray = str.toCharArray();
// 创建和字符串长度一样的byte 数组
byte[] byteArray = new byte[charArray.length];
// 循环从byte数组charArray读取数据,赋值给byte数组byteArray
for (int i = 0; i < charArray.length; i++) {
byteArray[i] = (byte) charArray[i];
}
// 获得密文
byte[] md5Bytes = md5.digest(byteArray);
// 把密文转换成十六进制的字符串形式
StringBuffer hexValue = new StringBuffer();
// 字节数组转换为 十六进制数
for (int i = 0; i < md5Bytes.length; i++) {
int val = ((int) md5Bytes[i]) & 0xff;
if (val < 16) {
hexValue.append("0");
}
hexValue.append(Integer.toHexString(val));
}
return hexValue.toString();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
// MD5解密 执行一次加密,两次解密
public static String decryptMD5(String str) {
if (null == str) {
return null;
}
char[] decryptStr = str.toCharArray();
for (int i = 0; i < decryptStr.length; i++) {
decryptStr[i] = (char) (decryptStr[i] ^ 't');
}
String decryptResult = new String(decryptStr);
return decryptResult;
}
}