国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 广水市| 海安县| 麟游县| 水富县| 祥云县| 大安市| 邢台市| 叙永县| 南陵县| 罗定市| 新野县| 弥勒县| 双江| 敦化市| 五台县| 长阳| 杭锦旗| 肃北| 武义县| 朝阳区| 岗巴县| 加查县| 芜湖县| 浦县| 丰台区| 格尔木市| 榆中县| 诸暨市| 滨州市| 荣成市| 威远县| 莱芜市| 河曲县| 韩城市| 兴宁市| 象山县| 嘉峪关市| 建阳市| 巫山县| 和政县| 诏安县|