日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

信息加密之信息摘要加密MD2、MD4、MD5

發(fā)布時間:2023/12/10 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 信息加密之信息摘要加密MD2、MD4、MD5 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

   對于用戶數(shù)據(jù)的保密一直是各個互聯(lián)網(wǎng)企業(yè)頭疼的事,那如何防止用戶的個人信息泄露呢?今天為大家介紹一種最簡單的加密方式--信息摘要算法MD。它如何來保護(hù)用戶的個人信息呢?其實很簡單,當(dāng)獲得到用戶的信息后,先對其進(jìn)行加密,然后將加密的結(jié)果保存到數(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為設(shè)置的一個字符串。

  到這里消息摘要加密算法的MD2\4\5的實現(xiàn)到此講解完畢,對Base64和對稱加密算法有興趣的朋友可以看一下我之前分享的博客。小生很喜歡信息安全,那位有興趣,歡迎交流。(1453296946@qq.com)

轉(zhuǎn)載于:https://www.cnblogs.com/AndroidJotting/p/4284337.html

總結(jié)

以上是生活随笔為你收集整理的信息加密之信息摘要加密MD2、MD4、MD5的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。