标签:md originalBytes 加密 String hex import java byte md5
前言
md5加密是不可逆的
一、jdk实现md5加密
package com.example.baidu; import org.junit.Test; import java.nio.charset.StandardCharsets; import java.security.MessageDigest; public class M大JdkTest { @Test public void test() throws Exception { String str = "银河系的极光"; // 定义编码 String algorithm = "MD5"; // 获取消息摘要算法对象 MessageDigest md = MessageDigest.getInstance(algorithm); // 获取原始内容的字节数组 byte[] originalBytes = str.getBytes(StandardCharsets.UTF_8); // 获取摘要结果 byte[] digestBytes = md.digest(originalBytes); // 当originalBytes比较大的时候,循环进行update /*md.update(originalBytes); md.digest();*/ // 把每一个字节转换为16进制字节,最后再将它们拼接起来 String hexStr = convertBytes2HexStr(originalBytes); System.out.printf("hexStr: " + hexStr); } private String convertBytes2HexStr(byte[] originalBytes) { StringBuffer sb = new StringBuffer(); for (byte bt : originalBytes) { // 获取b补码后的八位 String hex = Integer.toHexString(((int)bt)&0xff); if (hex.length() == 1) { hex = "0" + hex; } sb.append(hex); } return sb.toString(); } }
标签:md,originalBytes,加密,String,hex,import,java,byte,md5 来源: https://www.cnblogs.com/hu0529/p/16535511.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。