MD5和一个可逆加密算法相接合的加密和解密程序

MD5和一个可逆加密算法相接合的加密和解密程序  
比较简单。   
import java.security.MessageDigest;  
/**  
*先通过MD5加密之后,再来一次可逆的加密。  
*顺序可以调整,可以选择先用可逆加密,然后再用MD5加密  
*/
public class MD5andKL{  
//MD5加码。32位  
public static String MD5(String inStr) {  
MessageDigest md5 = null;  
try {  
md5 = MessageDigest.getInstance("MD5");  
} catch (Exception e) {  
System.out.println(e.toString());  
e.printStackTrace();  
return "";  
}  
char[] charArray = inStr.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();  
}  
   
//可逆的加密算法  
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;   
}  
//加密后解密  
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("http://www.daimami.com");  
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))));  
}  
}

 

你可能感兴趣的:(算法)