java md5 加密 32位/16位

本文介绍了一种使用Java实现的MD5加密算法,通过MessageDigest类提供的MD5或SHA等信息摘要算法来确保数据的安全性。文章提供了完整的代码示例,展示了如何将任意长度的输入转换为固定长度的哈希值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
* 记得以前写过,找不到了……
* 百度的空间内容搜索还是不太理想……
* 再写一次吧……
*/
import java.security.MessageDigest;

public class Md5 {

/**
* md5加密方法
* @author: zhengsunlei
* Jul 30, 2010 4:38:28 PM
* @param plainText 加密字符串
* @return String 返回32位md5加密字符串(16位加密取substring(8,24))
* 每位工程师都有保持代码优雅的义务
* each engineer has a duty to keep the code elegant
*/
public final static String md5(String plainText) {

// 返回字符串
String md5Str = null;
try {
// 操作字符串
StringBuffer buf = new StringBuffer();

/**
* MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。
* 信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。
*
* MessageDigest 对象开始被初始化。
* 该对象通过使用 update()方法处理数据。
* 任何时候都可以调用 reset()方法重置摘要。
* 一旦所有需要更新的数据都已经被更新了,应该调用digest()方法之一完成哈希计算。
*
* 对于给定数量的更新数据,digest 方法只能被调用一次。
* 在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态。
*/
MessageDigest md = MessageDigest.getInstance("MD5");

// 添加要进行计算摘要的信息,使用 plainText 的 byte 数组更新摘要。
md.update(plainText.getBytes());

// 计算出摘要,完成哈希计算。
byte b[] = md.digest();
int i;

for (int offset = 0; offset < b.length; offset++) {

i = b[offset];

if (i < 0) {
i += 256;
}

if (i < 16) {
buf.append("0");
}

// 将整型 十进制 i 转换为16位,用十六进制参数表示的无符号整数值的字符串表示形式。
buf.append(Integer.toHexString(i));

}

// 32位的加密
md5Str = buf.toString();

// 16位的加密
// md5Str = buf.toString().md5Strstring(8,24);

} catch (Exception e) {
e.printStackTrace();
}
return md5Str;
}
}

java加密算法IBM详细:https://www.ibm.com/developerworks/cn/java/l-security/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值