MD5加密

MD5是一种不可逆的加密算法,虽然该加密算法已经被破解,但是对于一些安全要求不是特别高的应用还是比较好的选择。若是希望安全级别更高一点的加密算法可以考虑RSA非对称加密等。
虽说不同语言的md5加密算法是一样的,但是若是不是和外部应用进行交互的话,也可以对md5进行自定义规则。以提高安全性。
一、MD5实例
public class MD5Util{
    //可以约束生成的MD5是16进制或是8进制的,本文使用十六进制的
    //定义16进制对应的字符数组
    private static char[] chars = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9','a', 'b', 'c', 'd', 'e', 'f'};
  
   //进行md5加密
  public final static md5(String message,String key){
  try{
      byte[] bytes = (key+message).getBytes();
      MessageDigest mdTemp = MessageDigest.getInstance("MD5");
      mdTemp.update(bytes);
      byte[] mdBytes = mdTemp.digest();//生成固定16长度的字节数组
      int length = mdBytes.length;
      //下面就是第三点可以自定义的部分,标准的如下
       int j = 2;//md5最后生成的长度为j*16
       char[] desChars = new char[length*j];
      int k = 0;
      for(int i = 0 ; i < length ; i++){
      Byte byte = mdBytes[i];
//只保留byte的最后4位,定义成16进制的就要用oxf
      //下面的部分也可以自定义,只要保留出4位,8进制就用07
      desChars[k++] = hexDigits[byte >>> 4 & 0xf];
      desChars[k++] = hexDigits[byte0 & 0xf];  
}       
    return new String(desChars);
   }catch(Exception e){}
   return null;
}
}

你可能感兴趣的:(MD5加密)