zoukankan      html  css  js  c++  java
  • MD5 Hashing in Java,Written by dimport

    A wrapper for Java's MD5 class that makes life a little easier.

    This class lets you produce an MD5 hashcode for some binary data. It is useful for storing passwords in databases or file systems, or for checking the validity of downloaded files. It also provides an example of the singleton design pattern.

     import java.security.*;
     
     public class MD5
     {
     
       private MessageDigest md = null;
       static private MD5 md5 = null;
       private static final char[] hexChars ={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
     
       /**
        * Constructor is private so you must use the getInstance method
        */
       private MD5() throws NoSuchAlgorithmException
       {
         md = MessageDigest.getInstance("MD5");
       }
     
     
       /**
       * This returns the singleton instance
       */
      public static MD5 getInstance()throws NoSuchAlgorithmException
       {
         
           if (md5 == null)
           {
             md5 = new MD5();
     
         }
         
         return (md5);
       }
     
       public String hashData(byte[] dataToHash)
     
     {
     
       return hexStringFromBytes((calculateHash(dataToHash)));
       }
     
     
     
     private byte[] calculateHash(byte[] dataToHash)
     
     {
          md.update(dataToHash, 0, dataToHash.length);
     
         return (md.digest());
      }
     
     
     
     public String hexStringFromBytes(byte[] b)
     
     {
     
       String hex = "";
     
       int msb;
     
       int lsb = 0;
         int i;
     
       // MSB maps to idx 0
     
       for (i = 0; i < b.length; i++)
     
       {
     
         msb = ((int)b[i] & 0x000000FF) / 16;
     
         lsb = ((int)b[i] & 0x000000FF) % 16;
           hex = hex + hexChars[msb] + hexChars[lsb];
         }
         return(hex);
       }
     
     
         public static void main(String[] args)
         {
             try
             {
        
            MD5 md = MD5.getInstance();
                 System.out.println(md.hashData("hello".getBytes()));
             }
             catch(NoSuchAlgorithmException e)
             {
                 e.printStackTrace(System.out);
             }
         }
     }

  • 相关阅读:
    6.25作业
    博客园第一篇
    532. 数组中的K-diff数对
    echarts
    跨域问题
    数组中第三大的数 leetcode 414
    除自身以外数组的乘积leetcode 238
    xshell工具
    插入、删除和随机查询时间复杂度都为O(1) leetcode 381
    组合总和3 leetcode 216
  • 原文地址:https://www.cnblogs.com/MaxWoods/p/705428.html
Copyright © 2011-2022 走看看