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("admin");
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))));
}
}发个代码,随便测试一下能不能发JAVA CODE 的格式。之前没有发成功!

解决方案 »

  1.   

    此回复为自动发出,仅用于显示而已,并无任何其他特殊作用
    楼主【jishu_vip】截止到2008-07-05 14:20:21的历史汇总数据(不包括此帖):
    发帖的总数量:4                        发帖的总分数:20                       
    结贴的总数量:3                        结贴的总分数:20                       
    无满意结贴数:0                        无满意结贴分:0                        
    未结的帖子数:1                        未结的总分数:0                        
    结贴的百分比:75.00 %               结分的百分比:100.00%                  
    无满意结贴率:0.00  %               无满意结分率:0.00  %                  
    楼主加油