Imooc_Java實現消息摘要算法加密_2-2MD算法實現

原視頻地址
Imooc_Java實現消息摘要算法加密_2-2MD算法實現

package MD;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.Security;

import org.apache.commons.codec.binary.Hex;
import org.apache.commons.codec.digest.DigestUtils;
import org.bouncycastle.crypto.Digest;
import org.bouncycastle.crypto.digests.MD2Digest;
import org.bouncycastle.crypto.digests.MD4Digest;
import org.bouncycastle.crypto.digests.MD5Digest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;

public class MD {

    private static String src = "imooc security md";


    public static void main(String[] args) {
        jdkMD5();
        jdkMD2();
         bcMD4();
         newbcMD4();
         bcMD5();
         bcMD2();
         ccMD5();
         ccMD2();
    }


    private static void jdkMD5(){
        try {
            //MessageDigest 直接調用靜態方法getInstance 指定md是MD5算法的執行者
            MessageDigest md = MessageDigest.getInstance("MD5");
            byte[] md5Bytes = md.digest(src.getBytes());
            //將md5Bytes數組轉爲16進制  兩種方法  :  第三方的包    或者   自己寫個代碼轉爲16進制
            //用第三方包轉16進制輸出
            System.out.println("jdkMD5:"+Hex.encodeHexString(md5Bytes));
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }//jdkMD5()方法結束


    private static void jdkMD2(){
        try {
            //MessageDigest 直接調用靜態方法getInstance 指定md是MD5算法的執行者
            MessageDigest md = MessageDigest.getInstance("MD2");
            byte[] md2Bytes = md.digest(src.getBytes());
            //將md5Bytes數組轉爲16進制  兩種方法  :  第三方的包    或者   自己寫個代碼轉爲16進制
            //用第三方包轉16進制輸出
            System.out.println("jdkMD2:"+Hex.encodeHexString(md2Bytes));
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }//jdkMD2()方法結束

    private static void bcMD4(){
        Digest digest = new MD4Digest();
        //update(要被處理的內容 ,從哪開始處理,處理長度)
        digest.update(src.getBytes(), 0, src.getBytes().length);
        byte[] md4Bytes = new byte[digest.getDigestSize()];
        //doFinal(對摘要進行輸出的內容,偏移量)
        digest.doFinal(md4Bytes, 0);
        System.out.println("bcMD4:"+org.bouncycastle.util.encoders.Hex.toHexString(md4Bytes));
    }//bcMD4方法結束


    private static void newbcMD4(){
        try {
            //動態給JDK添加BouncyCastleProvider
            Security.addProvider(new BouncyCastleProvider());
            MessageDigest md  = MessageDigest.getInstance("MD4");
            byte[] bcmd4Bytes = md.digest(src.getBytes());
            //將md5Bytes數組轉爲16進制  兩種方法  :  第三方的包    或者   自己寫個代碼轉爲16進制
            //用第三方包轉16進制輸出
            System.out.println("newbcMD4()"+Hex.encodeHexString(bcmd4Bytes));
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }

    }//newbcMD4方法結束

    private static void bcMD5(){
        Digest digest = new MD5Digest();
        //update(要被處理的內容 ,從哪開始處理,處理長度)
        digest.update(src.getBytes(), 0, src.getBytes().length);
        byte[] md5Bytes = new byte[digest.getDigestSize()];
        //doFinal(對摘要進行輸出的內容,偏移量)
        digest.doFinal(md5Bytes, 0);
        System.out.println("bcMD5:"+org.bouncycastle.util.encoders.Hex.toHexString(md5Bytes));
    }//bcMD5方法結束

    private static void bcMD2(){
        Digest digest = new MD2Digest();
        //update(要被處理的內容 ,從哪開始處理,處理長度)
        digest.update(src.getBytes(), 0, src.getBytes().length);
        byte[] md2Bytes = new byte[digest.getDigestSize()];
        //doFinal(對摘要進行輸出的內容,偏移量)
        digest.doFinal(md2Bytes, 0);
        System.out.println("bcMD2:"+org.bouncycastle.util.encoders.Hex.toHexString(md2Bytes));
    }//bcMD2方法結束

    public static void ccMD5(){
        //工具類DigestUtils
        System.out.println("ccMD5:"+DigestUtils.md5Hex(src.getBytes()));
    }

    public static void ccMD2(){
        //工具類DigestUtils
        System.out.println("ccMD2:"+DigestUtils.md2Hex(src.getBytes()));
    }


}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章