原視頻地址
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()));
}
}