密碼加密MD5,Bash64


基於jar : org.apache.commons.codec

一、MD5概述:不可逆加密

Message Digest Algorithm MD5(中文名為消息摘要算法第 五版)為計算機安全領域廣泛使用的一種散列函數,用以提供消息的完整性保護。

MD5即Message-Digest Algorithm 5(信息-摘要算法5),用於確保信息傳輸完整一致。是計算機廣泛使用的雜湊算法之一(又譯摘要算法、哈希算法),主流編程語言普遍已有MD5實現。將數據(如漢字)運算為另一固定長度值,是雜湊算法的基礎原理,MD5的前身有MD2、MD3和MD4。
  MD5算法具有以下特點:
  1、壓縮性:任意長度的數據,算出的MD5值長度都是固定的。
  2、容易計算:從原數據計算出MD5值很容易。
  3、抗修改性:對原數據進行任何改動,哪怕只修改1個字節,所得到的MD5值都有很大區別。
  4、強抗碰撞:已知原數據和其MD5值,想找到一個具有相同MD5值的數據(即偽造數據)是非常困難的。

  MD5的作用是讓大容量信息在用數字簽名軟件簽署私人密鑰前被"壓縮"成一種保密的格式(就是把一個任意長度的字節串變換成一定長的十六進制數字串)。

  一般不對Md5解密,而是通過比對,再一次獲取密碼進行加密后比對前后是否一致

String str2 = "abc";
System.out.println(DigestUtils.md5Hex(str2));
//輸出:900150983cd24fb0d6963f7d28e17f72

二、Bash64:可逆加密

 

//加密
String str= "abc";
byte[] b = Base64.encodeBase64(str.getBytes(), true);
System.out.println(new String(b));  //YWJj
//解密
String str1 = "YWJj";
byte[] b1 = Base64.decodeBase64(str1.getBytes());
System.out.println(new String(b1)); //abc
        

 借鑒:https://www.cnblogs.com/zhuyuewei/p/6401393.html


免責聲明!

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



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