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
- Imooc_Java实现消息摘要算法加密_2-2MD算法实现
- Imooc_Java实现消息摘要算法加密_3-2SHA算法实现
- Imooc_Java实现消息摘要算法加密_4-1 消息摘要算法MAC实现与应用
- Imooc_Java实现Base64加密_2-1实现Base64算法
- 消息摘要算法加密(代码实现)
- 消息摘要算法加密
- 消息摘要算法-SHA算法实现
- java消息摘要算法加密
- java消息摘要算法加密
- java消息摘要算法加密
- Java消息摘要算法加密
- 消息摘要算法HmacMD5的实现
- Java实现MD5消息摘要算法
- 消息摘要算法MAC实现与应用
- MD算法Java实现
- MD(Message Digest ) 消息摘要算法之MD5
- MD(Message Digest ) 消息摘要算法之SHA
- MD(Message Digest ) 消息摘要算法之HMAC
- HttpClient实现简单的网络爬虫功能
- ASCLL排序
- 今天移植ILI9341液晶屏时出现的小问题导致的时间浪费
- OKVIS 中的 propagation 代码公式版
- MapReduce 1底层实现原理
- Imooc_Java实现消息摘要算法加密_2-2MD算法实现
- centos7下快速安装mysql
- SpringMVC引入静态org.webjars中资源404
- 展开Verilog BUS信号名的方法
- OKVIS 中的 propagation 公式版
- Imooc_Java实现消息摘要算法加密_3-2SHA算法实现
- JAVA中值传递和引用传递的三种情况
- Java之路第一天
- eclipse的svn连不上SVN Server服务器