国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

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

2019-11-14 22:58:22
字體:
來源:轉載
供稿:網(wǎng)友
信息加密之信息摘要加密MD2、MD4、md5

   對于用戶數(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)


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 游戏| 三原县| 电白县| 高州市| 那曲县| 鹿邑县| 昭觉县| 舞钢市| 弥勒县| 宜州市| 青阳县| 大邑县| 察雅县| 东乡| 陵川县| 安平县| 微博| 贡觉县| 珲春市| 浦东新区| 曲阜市| 邹城市| 江北区| 水富县| 克东县| 札达县| 中阳县| 永靖县| 桦川县| 泰来县| 额尔古纳市| 枣强县| 富川| 瑞安市| 清水河县| 包头市| 十堰市| 会宁县| 清丰县| 高陵县| 富宁县|