java的md5加密原理_MD5加密算法的java实现

这是一个关于如何在Java中实现MD5加密算法的示例。通过`MessageDigest`类获取MD5实例,并将字符串转换为哈希值,最终将字节数组转化为16进制字符串。
摘要由CSDN通过智能技术生成

package other;

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

/*

* MD5 算法

*/

public class MD5 {

// 全局数组

private final static String[] strDigits = { "0", "1", "2", "3", "4", "5",

"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };

public MD5() {

}

// 返回形式为数字跟字符串

private static String byteToArrayString(byte bByte) {

int iRet = bByte;

// System.out.println("iRet="+iRet);

if (iRet < 0) {

iRet += 256;

}

int iD1 = iRet / 16;

int iD2 = iRet % 16;

return strDigits[iD1] + strDigits[iD2];

}

// 返回形式只为数字

private static String byteToNum(byte bByte) {

int iRet = bByte;

System.out.println("iRet1=" + iRet);

if (iRet < 0) {

iRet += 256;

}

return String.valueOf(iRet);

}

// 转换字节数组为16进制字串

private static String byteToString(byte[] bByte) {

StringBuffer sBuffer = new StringBuffer();

for (int i = 0; i < bByte.length; i++) {

sBuffer.append(byteToArrayString(bByte[i]));

}

return sBuffer.toString();

}

public static String GetMD5Code(String strObj) {

String resultString = null;

try {

resultString = new String(strObj);

MessageDigest md = MessageDigest.getInstance("MD5");

// md.digest() 该函数返回值为存放哈希值结果的byte数组

resultString = byteToString(md.digest(strObj.getBytes()));

} catch (NoSuchAlgorithmException ex) {

ex.printStackTrace();

}

return resultString;

}

public static void main(String[] args) {

MD5 getMD5 = new MD5();

System.out.println(getMD5.GetMD5Code("000000"));

}

}

原文:http://www.cnblogs.com/qihuan/p/3798673.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答关于Java实现MD5加密解密的问题。 Java提供了MessageDigest类来实现MD5加密,可以通过以下代码实现: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return Base64.getEncoder().encodeToString(bytes); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 上述代码中,`encrypt`方法用于实现MD5加密,参数为需要加密的字符串,返回值为加密后的字符串。`decrypt`方法用于实现MD5加密后的字符串的解密,但是由于MD5是不可逆的加密算法,所以我们无法进行解密,因此在该方法中直接抛出了`UnsupportedOperationException`异常。 使用示例: ```java public class Main { public static void main(String[] args) { String password = "123456"; String encryptedPassword = MD5Util.encrypt(password); System.out.println("加密后的密码:" + encryptedPassword); } } ``` 输出结果: ``` 加密后的密码:MTIzNDU2Nzg5MDM0NTY3OA== ``` 可以看到,加密后的密码是一串Base64编码的字符串。如果需要将其转换为16进制字符串,可以使用以下代码: ```java import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return new BigInteger(1, bytes).toString(16); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 这样输出的加密后的密码就是16进制的字符串了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值