import java.security.MessageDigest;public classMD5Util {/***
* MD5加密 生成32位md5码
* @param 待加密字符串
* @return 返回32位md5码*/
public staticString MD5(String inStr) throws Exception {
MessageDigest md5= null;try{
md5= MessageDigest.getInstance("MD5");
}catch(Exception e) {
System.out.println(e.toString());
e.printStackTrace();return "";
}byte[] byteArray = inStr.getBytes("UTF-8");byte[] md5Bytes =md5.digest(byteArray);
StringBuffer hexValue= newStringBuffer();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));
}returnhexValue.toString();
}//一次加密两次解密
public staticString convertMD5(String inStr) {char[] a =inStr.toCharArray();for (int i = 0; i < a.length; i++) {
a[i]= (char) (a[i] ^ ‘t‘);
}
String s= newString(a);returns;
}//可逆的加密算法
public staticString 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= newString(a);returns;
}//加密后解密
public staticString JM(String inStr) {char[] a =inStr.toCharArray();for (int i = 0; i < a.length; i++) {
a[i]= (char) (a[i] ^ ‘t‘);
}
String k= newString(a);returnk;
}/**
* 测试主函数
*
* @param args
* @throws Exception*/
//密码先加密,然后再比较是否相等
public static voidmain(String args[]) throws Exception {
String str= new String("abc");
System.out.println("原始:" +str);
System.out.println("MD5后:" +MD5(str));
System.out.println(convertMD5(str));
System.out.println(convertMD5(convertMD5(str)));
String s= new String("123123");//4297f44b13955235245b2497399d7a93
System.out.println("原始:" +str);
System.out.println("MD5后:" +MD5(str));
System.out.println("MD5后再加密:" +KL(MD5(str)));
System.out.println("解密为MD5后的:" +JM(KL(MD5(str))));
}
}