真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java信息摘要加密MD2、MD4、MD5實(shí)現(xiàn)詳解

對(duì)于用戶數(shù)據(jù)的保密一直是各個(gè)互聯(lián)網(wǎng)企業(yè)頭疼的事,那如何防止用戶的個(gè)人信息泄露呢?今天為大家介紹一種最簡(jiǎn)單的加密方式--信息摘要算法MD。它如何來(lái)保護(hù)用戶的個(gè)人信息呢?其實(shí)很簡(jiǎn)單,當(dāng)獲得到用戶的信息后,先對(duì)其進(jìn)行加密,然后將加密的結(jié)果保存到數(shù)據(jù)庫(kù),這樣即使被盜,用戶的數(shù)據(jù)也不會(huì)丟失。下面上代碼:

創(chuàng)新互聯(lián)專注于連云港企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開(kāi)發(fā),商城網(wǎng)站建設(shè)。連云港網(wǎng)站建設(shè)公司,為連云港等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

JAVA的jdk提供了MD2和MD5的加密方式, JAVA不支持MD4的jdk加密方式,jdk的實(shí)現(xiàn)如下:

private static void MD2_jdk(){
    try {
      MessageDigest digest = MessageDigest.getInstance("MD2");//獲得消息摘要MD2對(duì)象
      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對(duì)象
      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的加密實(shí)現(xiàn)(bc使用需要添加bc的jar包):

private static void MD2_bc(){
    Digest digest = new MD2Digest();//通過(guò)BC獲得消息摘要MD2對(duì)象
    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();//通過(guò)BC獲得消息摘要MD4對(duì)象
    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();//通過(guò)BC獲得消息摘要MD5對(duì)象
    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));
  }

通過(guò)bc為jdk添加一個(gè)動(dòng)態(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的實(shí)現(xiàn):

DigestUtils.md2Hex(src.getBytes());
DigestUtils.md5Hex(src.getBytes());

注:src為設(shè)置的一個(gè)字符串。

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


標(biāo)題名稱:Java信息摘要加密MD2、MD4、MD5實(shí)現(xiàn)詳解
網(wǎng)頁(yè)網(wǎng)址:http://weahome.cn/article/gpsdes.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部