原视频地址
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()));
}
}