關於java中MD5加密(可直接使用)


本文轉自:http://www.cnblogs.com/solove/archive/2011/10/18/2216715.html

上部分是轉載的關於字符串的加密,后半部分則比較全,包括字符串、文件、字節數組、等

  1. package util; 
  2.  
  3. import java.security.MessageDigest; 
  4.  
  5. public class Encript { 
  6.     //十六進制下數字到字符的映射數組 
  7.     private final static String[] hexDigits = {"0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"}; 
  8.  
  9.     /**把inputString加密*/ 
  10.     public static String md5(String inputStr){ 
  11.         return encodeByMD5(inputStr); 
  12.     } 
  13.  
  14.     /** 
  15.     * 驗證輸入的密碼是否正確 
  16.     * @param password 真正的密碼(加密后的真密碼) 
  17.     * @param inputString 輸入的字符串 
  18.     * @return 驗證結果,boolean類型 
  19.     */ 
  20.     public static boolean authenticatePassword(String password,String inputString){ 
  21.         if(password.equals(encodeByMD5(inputString))){ 
  22.             return true; 
  23.         }else{ 
  24.             return false; 
  25.         } 
  26.     } 
  27.  
  28.     /**對字符串進行MD5編碼*/ 
  29.     private static String encodeByMD5(String originString){ 
  30.         if (originString!=null) { 
  31.             try { 
  32.                 //創建具有指定算法名稱的信息摘要 
  33.                 MessageDigest md5 = MessageDigest.getInstance("MD5"); 
  34.                 //使用指定的字節數組對摘要進行最后更新,然后完成摘要計算 
  35.                 byte[] results = md5.digest(originString.getBytes()); 
  36.                 //將得到的字節數組變成字符串返回  
  37.                 String result = byteArrayToHexString(results); 
  38.                 return result; 
  39.             } catch (Exception e) { 
  40.                 e.printStackTrace(); 
  41.             } 
  42.         } 
  43.         return null; 
  44.     } 
  45.  
  46.     /** 
  47.     * 輪換字節數組為十六進制字符串 
  48.     * @param b 字節數組 
  49.     * @return 十六進制字符串 
  50.     */ 
  51.     private static String byteArrayToHexString(byte[] b){ 
  52.         StringBuffer resultSb = new StringBuffer(); 
  53.         for(int i=0;i<b.length;i++){ 
  54.             resultSb.append(byteToHexString(b[i])); 
  55.         } 
  56.         return resultSb.toString(); 
  57.     } 
  58.  
  59.     //將一個字節轉化成十六進制形式的字符串 
  60.     private static String byteToHexString(byte b){ 
  61.         int n = b; 
  62.         if(n<0) 
  63.         n=256+n; 
  64.         int d1 = n/16; 
  65.         int d2 = n%16; 
  66.         return hexDigits[d1] + hexDigits[d2]; 
  67.     } 
  68. +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  69. package com.angsentech.ssm.util;

    import java.io.File;
    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.UnsupportedEncodingException;
    import java.security.MessageDigest;
    import java.security.NoSuchAlgorithmException;

    /**
    * MD5加密處理工具類
    * @author Administrator
    *
    */

    public class MD5Utils {
    /**
    * 默認的密碼字符串組合,用來將字節轉換成 16 進制表示的字符,apache校驗下載的文件的正確性用的就是默認的這個組合
    */
    protected static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6',
    '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };

    protected static MessageDigest messagedigest = null;
    static {
    try {
    messagedigest = MessageDigest.getInstance("MD5");
    } catch (NoSuchAlgorithmException nsaex) {
    System.err.println(MD5Utils.class.getName()
    + "初始化失敗,MessageDigest不支持MD5Util。");
    nsaex.printStackTrace();
    }
    }

    /**
    * 生成字符串的md5校驗值
    *
    * @param s
    * @return
    */
    public static String getMD5String(String s) {
    return getMD5String(s.getBytes());
    }

    /**
    * 判斷字符串的md5校驗碼是否與一個已知的md5碼相匹配
    *
    * @param password
    * 要校驗的字符串
    * @param md5PwdStr
    * 已知的md5校驗碼
    * @return
    */
    public static boolean isEqualsToMd5(String password, String md5PwdStr) {
    String s = getMD5String(password);
    return s.equals(md5PwdStr);
    }

    /**
    * 生成文件的md5校驗值
    *
    * @param file
    * @return
    * @throws IOException
    */
    public static String getFileMD5String(File file) throws IOException {
    InputStream fis;
    fis = new FileInputStream(file);
    byte[] buffer = new byte[1024];
    int numRead = 0;
    while ((numRead = fis.read(buffer)) > 0) {
    messagedigest.update(buffer, 0, numRead);
    }
    fis.close();
    return bufferToHex(messagedigest.digest());
    }

    /**
    * 生成字節數組的md5校驗值
    *
    * @param s
    * @return
    */
    public static String getMD5String(byte[] bytes) {
    messagedigest.update(bytes);
    return bufferToHex(messagedigest.digest());
    }

    private static String bufferToHex(byte bytes[]) {
    return bufferToHex(bytes, 0, bytes.length);
    }

    private static String bufferToHex(byte bytes[], int m, int n) {
    StringBuffer stringbuffer = new StringBuffer(2 * n);
    int k = m + n;
    for (int l = m; l < k; l++) {
    appendHexPair(bytes[l], stringbuffer);
    }
    return stringbuffer.toString();
    }

    private static void appendHexPair(byte bt, StringBuffer stringbuffer) {
    char c0 = hexDigits[(bt & 0xf0) >> 4];// 取字節中高 4 位的數字轉換, >>>
    // 為邏輯右移,將符號位一起右移,此處未發現兩種符號有何不同
    char c1 = hexDigits[bt & 0xf];// 取字節中低 4 位的數字轉換
    stringbuffer.append(c0);
    stringbuffer.append(c1);
    }

    /**
    * 將源字符串使用MD5加密為字節數組
    * @param source
    * @return
    */
    public static byte[] encode2bytes(String source) {
    byte[] result = null;
    try {
    MessageDigest md = MessageDigest.getInstance("MD5");
    md.reset();
    md.update(source.getBytes("UTF-8"));
    result = md.digest();
    } catch (NoSuchAlgorithmException e) {
    e.printStackTrace();
    } catch (UnsupportedEncodingException e) {
    e.printStackTrace();
    }

    return result;
    }

    /**
    * 將源字符串使用MD5加密為32位16進制數
    * @param source
    * @return
    */
    public static String encode2hex(String source) {
    byte[] data = encode2bytes(source);
    StringBuffer hexString = new StringBuffer();
    for (int i = 0; i < data.length; i++) {
    String hex = Integer.toHexString(0xff & data[i]);

    if (hex.length() == 1) {
    hexString.append('0');
    }

    hexString.append(hex);
    }

    return hexString.toString();
    }

    /**
    * 驗證字符串是否匹配
    * @param unknown 待驗證的字符串
    * @param okHex 使用MD5加密過的16進制字符串
    * @return 匹配返回true,不匹配返回false
    */
    public static boolean validate(String unknown , String okHex) {
    return okHex.equals(encode2hex(unknown));
    }
    }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM