博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java的MD5加密和解密
阅读量:4919 次
发布时间:2019-06-11

本文共 4360 字,大约阅读时间需要 14 分钟。

简单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. }  
[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. }  

 

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. }  
[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. }  

 

转载于:https://www.cnblogs.com/android-blogs/p/5305598.html

你可能感兴趣的文章
匿名函数递归调用自身
查看>>
【转】U-BOOT之三:u-boot移植一
查看>>
NOJ 1651 Red packet(二分)
查看>>
php 中间代码opcode
查看>>
Uva 1061 The Morning after Halloween
查看>>
777,755,644在linux中的权限表示
查看>>
【笔记】LR响应时间
查看>>
关于Cocos2d-x中对其他某个类的某个属性的获得
查看>>
Python BeautifulSoup库的用法
查看>>
吴裕雄--天生自然 R语言开发学习:数据集和数据结构
查看>>
vs+ef+mysql 环境设置
查看>>
validform 一款好用的表单验证插件
查看>>
24-Longest Palindromic Substring-Leetcode
查看>>
新的开始——3.3
查看>>
1600802014
查看>>
分区-格式化-挂载-使用
查看>>
Zabbix 3.0入门到企业实战一(介绍监控的目的需求)
查看>>
Building a WPF Sudoku Game: Part 5 - The AI Battle: Loading and Comparing AI Plug-ins
查看>>
Linux-10Year
查看>>
将 Range 对象赋给变量
查看>>