zoukankan      html  css  js  c++  java
  • Java的MD5加密和解密

    简单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. }  
    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. }  
    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. }  
  • 相关阅读:
    BZOJ2648: SJY摆棋子
    BZOJ1925: [Sdoi2010]地精部落
    BZOJ1941: [Sdoi2010]Hide and Seek
    BZOJ2434: [Noi2011]阿狸的打字机
    BZOJ3295: [Cqoi2011]动态逆序对
    BZOJ1406: [AHOI2007]密码箱
    BZOJ1115: [POI2009]石子游戏Kam
    BZOJ1531: [POI2005]Bank notes
    BZOJ2730: [HNOI2012]矿场搭建
    计算几何《简单》入土芝士
  • 原文地址:https://www.cnblogs.com/android-blogs/p/5305598.html
Copyright © 2011-2022 走看看