关键字:MD5加密与解密艺术
import java.security.MessageDigest;
public class MD5 {
/**
* <pre>
* MD5加密。32位 .
* </pre>
*
* @param pstrPassword 未加密的原文密码
* @return the string
* @author 赵士杰 2011-4-29
*/
public static String md5(String pstrPassword) {
MessageDigest md5 = null;
try {
md5 = MessageDigest.getInstance("MD5");
} catch (Exception e) {
e.printStackTrace();
return "";
}
char[] charArray = pstrPassword.toCharArray();
byte[] byteArray = new byte[charArray.length];
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();
}
/**
* <pre>
* 可逆的加密算法(即:对MD5再进行加密).
* </pre>
*
* @param inStr the in str
* @return the string
* @author 赵士杰 2011-4-29
*/
public static String KL(String inStr) {
// String s = new String(inStr);
char[] a = inStr.toCharArray();
for (int i = 0; i < a.length; i++) {
a[i] = (char) (a[i] ^ 't');
}
String s = new String(a);
return s;
}
/**
* <pre>
* 加密后解密(即:将二次加密密码解密为 MD5格式).
* </pre>
*
* @param inStr the in str
* @return the string
* @author 赵士杰 2011-4-29
*/
public static String JM(String inStr) {
char[] a = inStr.toCharArray();
for (int i = 0; i < a.length; i++) {
a[i] = (char) (a[i] ^ 't');
}
String k = new String(a);
return k;
}
// 测试主函数
public static void main(String args[]) {
String s = new String("19840808zsj赵士杰");
System.out.println("原始:" + s);
System.out.println("MD5加密后:" + md5(s));
System.out.println("MD5后再加密:" + KL(md5(s)));
System.out.println("解密为MD5后的:" + JM(KL(md5(s))));
System.out.println("加密的:" + KL(s));
System.out.println("解密的:" + JM(KL(s)));
}
}
import java.security.MessageDigest;
public class MD5 {
/**
* <pre>
* MD5加密。32位 .
* </pre>
*
* @param pstrPassword 未加密的原文密码
* @return the string
* @author 赵士杰 2011-4-29
*/
public static String md5(String pstrPassword) {
MessageDigest md5 = null;
try {
md5 = MessageDigest.getInstance("MD5");
} catch (Exception e) {
e.printStackTrace();
return "";
}
char[] charArray = pstrPassword.toCharArray();
byte[] byteArray = new byte[charArray.length];
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();
}
/**
* <pre>
* 可逆的加密算法(即:对MD5再进行加密).
* </pre>
*
* @param inStr the in str
* @return the string
* @author 赵士杰 2011-4-29
*/
public static String KL(String inStr) {
// String s = new String(inStr);
char[] a = inStr.toCharArray();
for (int i = 0; i < a.length; i++) {
a[i] = (char) (a[i] ^ 't');
}
String s = new String(a);
return s;
}
/**
* <pre>
* 加密后解密(即:将二次加密密码解密为 MD5格式).
* </pre>
*
* @param inStr the in str
* @return the string
* @author 赵士杰 2011-4-29
*/
public static String JM(String inStr) {
char[] a = inStr.toCharArray();
for (int i = 0; i < a.length; i++) {
a[i] = (char) (a[i] ^ 't');
}
String k = new String(a);
return k;
}
// 测试主函数
public static void main(String args[]) {
String s = new String("19840808zsj赵士杰");
System.out.println("原始:" + s);
System.out.println("MD5加密后:" + md5(s));
System.out.println("MD5后再加密:" + KL(md5(s)));
System.out.println("解密为MD5后的:" + JM(KL(md5(s))));
System.out.println("加密的:" + KL(s));
System.out.println("解密的:" + JM(KL(s)));
}
}