Java的MD5加密和解密

本文提供两个 Java 类实现 MD5 加密的示例。第一个示例展示了如何使用 `MessageDigest` 类来生成字符串的 MD5 哈希值,并通过十六进制字符展示。第二个示例进一步演示了如何结合另一种简单的加密算法对 MD5 结果进行二次加密及解密。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单demo:

Java代码  收藏代码
  1. import  java.security.*;  
  2. import  java.security.spec.*;  
  3.   
  4. class  MD5_test {  
  5.  public   final   static  String MD5(String s) {  
  6.   char  hexDigits[] = {  '0''1''2''3''4''5''6''7''8''9' ,  
  7.     'a''b''c''d''e''f'  };  
  8.   try  {  
  9.    byte [] strTemp = s.getBytes();  
  10.    MessageDigest mdTemp = MessageDigest.getInstance("MD5" );  
  11.    mdTemp.update(strTemp);  
  12.    byte [] md = mdTemp.digest();  
  13.    int  j = md.length;  
  14.    char  str[] =  new   char [j *  2 ];  
  15.    int  k =  0 ;  
  16.    for  ( int  i =  0 ; i < j; i++) {  
  17.     byte  byte0 = md[i];  
  18.     str[k++] = hexDigits[byte0 >>> 4  &  0xf ];  
  19.     str[k++] = hexDigits[byte0 & 0xf ];  
  20.    }  
  21.    return   new  String(str);  
  22.   } catch  (Exception e) {  
  23.    return   null ;  
  24.   }  
  25.  }  
  26.   
  27.  public   static   void  main(String[] args) {  
  28.   // MD5_Test aa = new MD5_Test();   
  29.   System.out.print(MD5_test.MD5("b" ));  
  30.  }  
  31. }  
import java.security.*;
import java.security.spec.*;

class MD5_test {
 public final static String MD5(String s) {
  char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
    'a', 'b', 'c', 'd', 'e', 'f' };
  try {
   byte[] strTemp = s.getBytes();
   MessageDigest mdTemp = MessageDigest.getInstance("MD5");
   mdTemp.update(strTemp);
   byte[] md = mdTemp.digest();
   int j = md.length;
   char str[] = new char[j * 2];
   int k = 0;
   for (int i = 0; i < j; i++) {
    byte byte0 = md[i];
    str[k++] = hexDigits[byte0 >>> 4 & 0xf];
    str[k++] = hexDigits[byte0 & 0xf];
   }
   return new String(str);
  } catch (Exception e) {
   return null;
  }
 }

 public static void main(String[] args) {
  // MD5_Test aa = new MD5_Test();
  System.out.print(MD5_test.MD5("b"));
 }
}


Java代码  收藏代码
  1. import  java.security.MessageDigest;  
  2.   
  3.   
  4. public   class  MD5andKL {  
  5.  // MD5加码。32位   
  6.  public   static  String MD5(String inStr) {  
  7.   MessageDigest md5 = null ;  
  8.   try  {  
  9.    md5 = MessageDigest.getInstance("MD5" );  
  10.   } catch  (Exception e) {  
  11.    System.out.println(e.toString());  
  12.    e.printStackTrace();  
  13.    return   "" ;  
  14.   }  
  15.   char [] charArray = inStr.toCharArray();  
  16.   byte [] byteArray =  new   byte [charArray.length];  
  17.   
  18.   for  ( int  i =  0 ; i < charArray.length; i++)  
  19.    byteArray[i] = (byte ) charArray[i];  
  20.   
  21.   byte [] md5Bytes = md5.digest(byteArray);  
  22.   
  23.   StringBuffer hexValue = new  StringBuffer();  
  24.   
  25.   for  ( int  i =  0 ; i < md5Bytes.length; i++) {  
  26.    int  val = (( int ) md5Bytes[i]) &  0xff ;  
  27.    if  (val <  16 )  
  28.     hexValue.append("0" );  
  29.    hexValue.append(Integer.toHexString(val));  
  30.   }  
  31.   
  32.   return  hexValue.toString();  
  33.  }  
  34.   
  35.  // 可逆的加密算法   
  36.  public   static  String KL(String inStr) {  
  37.   // String s = new String(inStr);   
  38.   char [] a = inStr.toCharArray();  
  39.   for  ( int  i =  0 ; i < a.length; i++) {  
  40.    a[i] = (char ) (a[i] ^  't' );  
  41.   }  
  42.   String s = new  String(a);  
  43.   return  s;  
  44.  }  
  45.   
  46.  // 加密后解密   
  47.  public   static  String JM(String inStr) {  
  48.   char [] a = inStr.toCharArray();  
  49.   for  ( int  i =  0 ; i < a.length; i++) {  
  50.    a[i] = (char ) (a[i] ^  't' );  
  51.   }  
  52.   String k = new  String(a);  
  53.   return  k;  
  54.  }  
  55.    
  56.  // 测试主函数   
  57.  public   static   void  main(String args[]) {  
  58.   String s = new  String( "a" );  
  59.   System.out.println("原始:"  + s);  
  60.   System.out.println("MD5后:"  + MD5(s));  
  61.   System.out.println("MD5后再加密:"  + KL(MD5(s)));  
  62.   System.out.println("解密为MD5后的:"  + JM(KL(MD5(s))));  
  63.  }  
  64. }  
import java.security.MessageDigest;


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("a");
  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))));
 }
}

 

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值