Imooc_Java实现消息摘要算法加密_2-2MD算法实现

来源:互联网 发布:华康少女字体mac 编辑:程序博客网 时间:2024/05/20 07:54

原视频地址
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()));    }}
0 0
原创粉丝点击