Java 信息摘要加密MD2、MD4、MD5實現(xiàn)詳解
對于用戶數(shù)據(jù)的保密一直是各個互聯(lián)網(wǎng)企業(yè)頭疼的事,那如何防止用戶的個人信息泄露呢?今天為大家介紹一種最簡單的加密方式--信息摘要算法MD。它如何來保護用戶的個人信息呢?其實很簡單,當獲得到用戶的信息后,先對其進行加密,然后將加密的結果保存到數(shù)據(jù)庫,這樣即使被盜,用戶的數(shù)據(jù)也不會丟失。下面上代碼:
JAVA的jdk提供了MD2和MD5的加密方式, JAVA不支持MD4的jdk加密方式,jdk的實現(xiàn)如下:
private static void MD2_jdk(){ try { MessageDigest digest = MessageDigest.getInstance("MD2");//獲得消息摘要MD2對象 byte[] md2Byte = digest.digest(src.getBytes()); System.out.println("md2Byte :"+md2Byte.toString()); System.out.println("md2Byte :"+Hex.encodeHexString(md2Byte)); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } } private static void MD5_jdk(){ try { MessageDigest digest = MessageDigest.getInstance("MD5");//獲得消息摘要MD5對象 byte[] md5Byte = digest.digest(src.getBytes()); System.out.println("md5Byte :"+md5Byte.toString()); System.out.println("md5Byte :"+Hex.encodeHexString(md5Byte)); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } }
bc提供了MD2\4\5的加密實現(xiàn)(bc使用需要添加bc的jar包):
private static void MD2_bc(){ Digest digest = new MD2Digest();//通過BC獲得消息摘要MD2對象 digest.update(src.getBytes(), 0, src.getBytes().length); byte[] md2Byte = new byte[digest.getDigestSize()]; digest.doFinal(md2Byte, 0); System.out.println("md2Byte :"+md2Byte.toString()); System.out.println("md2Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md2Byte)); } private static void MD4_bc(){ Digest digest = new MD4Digest();//通過BC獲得消息摘要MD4對象 digest.update(src.getBytes(), 0, src.getBytes().length); byte[] md4Byte = new byte[digest.getDigestSize()]; digest.doFinal(md4Byte, 0); System.out.println("md4Byte :"+md4Byte.toString()); System.out.println("md4Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md4Byte)); } private static void MD5_bc(){ Digest digest = new MD5Digest();//通過BC獲得消息摘要MD5對象 digest.update(src.getBytes(), 0, src.getBytes().length); byte[] md5Byte = new byte[digest.getDigestSize()]; digest.doFinal(md5Byte, 0); System.out.println("md5Byte :"+md5Byte.toString()); System.out.println("md5Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md5Byte)); }
通過bc為jdk添加一個動態(tài)的MD4方法:
private static void MD4_bc_jdk(){ try { Security.addProvider(new BouncyCastleProvider()); MessageDigest md = MessageDigest.getInstance("MD4"); byte[] md4Byte = md.digest(src.getBytes()); System.out.println("md4Byte :"+md4Byte.toString()); System.out.println("md4Byte :"+Hex.encodeHexString(md4Byte)); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } }
最后為大家介紹一下CC的MD2\5的實現(xiàn):
DigestUtils.md2Hex(src.getBytes()); DigestUtils.md5Hex(src.getBytes());
注:src為設置的一個字符串。
到這里消息摘要加密算法的MD2\4\5的實現(xiàn)到此講解完畢,對Base64和對稱加密算法有興趣的朋友可以看一下我之前分享的博客。小生很喜歡信息安全,那位有興趣,歡迎交流。(1453296946@qq.com)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Java MD5消息摘要算法原理及實現(xiàn)代碼
- Java實現(xiàn)md5和base64加密解密的示例代碼
- java加密MD5實現(xiàn)及密碼驗證代碼實例
- java代碼實現(xiàn)MD5加密及驗證過程詳解
- java常用工具類 Random隨機數(shù)、MD5加密工具類
- Java計算文本MD5加密值的方法示例
- Java對文本文件MD5加密并ftp傳送到遠程主機目錄的實現(xiàn)方法
- Java語言描述MD5加密工具類實例代碼
- java實現(xiàn)MD5加密的方法小結
- java 中 MD5加密的實例
- java 實現(xiàn)MD5加密算法的簡單實例
- Java實現(xiàn)MD5加密的方式與實例代碼
相關文章
SpringBoot啟動訪問localhost:8080報錯404的解決操作
這篇文章主要介紹了SpringBoot啟動訪問localhost:8080報錯404的解決操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10Spring Cloud @EnableFeignClients注解的屬性字段basePacka詳解
這篇文章主要介紹了Spring Cloud @EnableFeignClients注解的屬性字段basePacka詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09詳解Spring中@Valid和@Validated注解用法
本文將以新增一個員工為功能切入點,以常規(guī)寫法為背景,慢慢烘托出?@Valid?和?@Validated?注解用法詳解,文中的示例代碼講解詳細,感興趣的可以了解一下2022-07-07