MD5的加密和解密算法

首先给大家推荐一下我老师大神的人工智能教学网站。教学不仅零基础,通俗易懂,而且非常风趣幽默,还时不时有内涵黄段子!点这里可以跳转到网站





先解释下:

MD5是不可逆,这里的加密解密,你可以看到是对MD5算法先加密后解密,而不是对MD5的解密

package com.test; import java.security.MessageDigest; public class DecryptMD5 {		 // 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("sa");   	  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))));   	 }    } 

点这里可以跳转到人工智能网站

发表评论