实例:
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class HMacMD5
{
/**
* 计算参数的md5信息
* @param str 待处理的字节数组
* @return md5摘要信息
* @throws NoSuchAlgorithmException
*/
private static byte[] md5(byte[] str)
throws NoSuchAlgorithmException
{
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(str);
return md.digest();
}
/**
* 将待加密数据data,通过密钥key,使用hmac-md5算法进行加密,然后返回加密结果。
* 参照rfc2104 HMAC算法介绍实现。
* @author 尹星
* @param key 密钥
* @param data 待加密数据
* @return 加密结果
* @throws NoSuchAlgorithmException
*/
public static byte[] getHmacMd5Bytes(byte[] key,byte[] data) throws NoSuchAlgorithmException
{
/* HmacMd5 calculation formula: H(K XOR opad, H(K XOR ipad, text))
* HmacMd5 计算公式:H(K XOR opad, H(K XOR ipad, text))
* H代表hash算法,本类中使用MD5算法,K代表密钥,text代表要加密的数据
* ipad为0x36,opad为0x5C。
*/
int length = 64;
byte[] ipad = new byte[length];
byte[] opad = new byte[length];
for(int i = 0; i < 64; i++)
{
ipad[i] = 0x36;
opad[i] = 0x5C;
}
byte[] actualKey = key; //Actual key.
byte[] keyArr = new byte[length]; //Key bytes of 64 bytes length
/*If key's length is longer than 64,then use hash to digest it and use the result as actual key.
* 如果密钥长度,大于64字节,就使用哈希算法,计算其摘要,作为真正的密钥。
*/
if(key.length>length)
{
actualKey = md5(key);
}
for(int i = 0; i < actualKey.length; i++)
{
keyArr[i] = actualKey[i];
}
/*append zeros to K
* 如果密钥长度不足64字节,就使用0x00补齐到64字节。
*/
if(actualKey.length < length)
{
for(int i = actualKey.length; i < keyArr.length; i++)
keyArr[i] = 0x00;
}
/*calc K XOR ipad
* 使用密钥和ipad进行异或运算。
*/
byte[] kIpadXorResult = new byte[length];
for(int i = 0; i < length; i++)
{
kIpadXorResult[i] = (byte) (keyArr[i] ^ ipad[i]);
}
/*append "text" to the end of "K XOR ipad"
* 将待加密数据追加到K XOR ipad计算结果后面。
*/
byte[] firstAppendResult = new byte[kIpadXorResult.length+data.length];
for(int i=0;i<kIpadXorResult.length;i++)
{
firstAppendResult[i] = kIpadXorResult[i];
}
for(int i=0;i<data.length;i++)
{
firstAppendResult[i+keyArr.length] = data[i];
}
/*calc H(K XOR ipad, text)
* 使用哈希算法计算上面结果的摘要。
*/
byte[] firstHashResult = md5(firstAppendResult);
/*calc K XOR opad
* 使用密钥和opad进行异或运算。
*/
byte[] kOpadXorResult = new byte[length];
for(int i = 0; i < length; i++)
{
kOpadXorResult[i] = (byte) (keyArr[i] ^ opad[i]);
}
/*append "H(K XOR ipad, text)" to the end of "K XOR opad"
* 将H(K XOR ipad, text)结果追加到K XOR opad结果后面
*/
byte[] secondAppendResult = new byte[kOpadXorResult.length+firstHashResult.length];
for(int i=0;i<kOpadXorResult.length;i++)
{
secondAppendResult[i] = kOpadXorResult[i];
}
for(int i=0;i<firstHashResult.length;i++)
{
secondAppendResult[i+keyArr.length] = firstHashResult[i];
}
/*H(K XOR opad, H(K XOR ipad, text))
* 对上面的数据进行哈希运算。
*/
byte[] hmacMd5Bytes = md5(secondAppendResult);
return hmacMd5Bytes;
}
public static String getHmacMd5Str(String key,String data)
{
String result = "";
try
{
byte[] keyByte = key.getByte("UTF-8");
byte[] dataByte = data.getBytes("UTF-8");
byte[] hmacMd5Byte = getHmacMd5Bytes(keyByte,dataByte);
StringBuffer md5StrBuff = new StringBuffer();
for(int i=0;i<hmacMd5Byte.length;i++)
{
if(Integer.toHexString(0xFF&hmacMd5Byte[i]).length()==1))
md5StrBuff.append("0").append(Integer.toHexString(0xFF&hmacMd5Byte[i]);
else
md5StrBuff.append(Integer.toHexString(0xFF&hmacMd5Byte[i]);
}
result = md5StrBuff.toString().toUpperCase();
}
catch(Exception e)
{
logger.error("error getHmacMd5Str()",e);
}
return result;
}
}
分享到:
相关推荐
主要介绍了Python实现的HMacMD5加密算法,简单说明了HMAC-MD5加密算法的概念、原理并结合实例形式分析了Python实现HMAC-MD5加密算法的相关操作技巧,,末尾还附带了Java实现HMAC-MD5加密算法的示例,需要的朋友可以参考...
Java中的单向加密技术主要包括MD5、SHA以及HMAC,这些算法主要用于数据的完整性校验和安全性保护。下面我们将详细探讨这些加密算法及其在Java中的实现。 首先,MD5(Message-Digest Algorithm 5)是一种广泛应用的...
Vive.Crypto(Vive.Crypto对各种常用的加密算法进行封装,有 Base64、对称加密(DES、3DES、AES、SM4)、非对称加密(RSA、SM2)、Hash(MD4、MD5、HMAC、HMAC-MD5、HMAC-SHA1、HMAC-SHA256、HMAC-SHA384、HMAC-SHA...
上面的公式采用了 HMAC-SHA-1 算法,但是也可以使用 HMAC-MD5 等其它算法。HMAC 算法得出的值位数比较多,不方便用户输入,因此需要截断(Truncate)成为一组不太长十进制数(例如 6 位)。 计算完成之后客户端...
本文将深入探讨Java中常见的几种加密解密算法:SHA算法、HMAC算法、DES算法、PBE算法、AES算法、RSA算法、数字签名以及D-H算法。 1. SHA(Secure Hash Algorithm)算法: SHA是一种散列函数,它能将任意长度的输入...
取而代之的是采用了 Java 安全性框架中内置的 HMAC-MD5 算法,该算法公开透明,确保了可解析性与一致性。 对于 JS 版本,用户需要自行下载 ePass1000ND USB 驱动程序。通过调用此 USB 驱动程序,JS 可以完成所需的...
在Java中实现MD5和HMAC256(使用SHA-256作为哈希函数的HMAC)可以参照以下步骤: 1. **MD5计算**: - 引入`java.security.MessageDigest`类,该类提供了各种哈希算法的支持。 - 创建`MessageDigest`实例,指定...
在Java中实现HMAC,我们可以使用`java.security`包中的`Mac`类。 1. 算法概述: - HMAC使用一个密钥和一个消息作为输入,通过哈希函数生成一个固定长度的消息摘要。 - 它通常与迭代散列函数(如MD5或SHA-1)结合...
GmSSL-Java目前提供了随机数生成器、SM3哈希、SM3消息认证码(HMAC-SM3)、SM4加密(包括分组加密和CBC/CTR/GCM加密模式)、ZUC加密、SM2加密/签名、SM9加密/签名、SM2证书解析等功能,可以覆盖目前国密算法主要应用...
MD5、AES和HMAC是三种常用的加密算法,它们各有特点,用于不同场景。让我们深入了解一下这些加密技术及其在Android中的实现。 首先,MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,它将任意长度的...
MACs hmac-sha1,hmac-sha1-96,hmac-sha2-256,hmac-sha2-512,hmac-md5,hmac-md5-96,umac-64@openssh.com,umac-128@openssh.com,hmac-sha1-etm@openssh.com,hmac-sha1-96-etm@openssh.com,hmac-sha2-256-etm@openssh....
* 实现了 HMAC-MD5 算法,使用 javax.crypto.Mac 和 javax.crypto.SecretKey 等类来生成密钥和执行加密和认证操作。 * 实现了 HMAC-SHA1、HMAC-SHA224、HMAC-SHA256、HMAC-SHA384、HMAC-SHA512 等多种 HMAC 算法。 ...
MACs hmac-sha1,hmac-sha1-96,hmac-sha2-256,hmac-sha2-512,hmac-md5,hmac-md5-96,umac-64@openssh.com,umac-128@openssh.com,hmac-sha1-etm@openssh.com,hmac-sha1-96-etm@openssh.com,hmac-sha2-256-etm@openssh....
在Java中,通常使用HMAC(Hash-based Message Authentication Code)来实现MAC,如HMAC-SHA1或HMAC-MD5。 以下是一个使用HMAC-SHA1生成MAC值的示例: ```java import javax.crypto.Mac; import javax.crypto.spec....
以上代码分别展示了如何在Java中实现MD5和SHA1哈希以及HMAC SHA1的计算。在实际应用中,这些工具常用于数据存储、密码存储、消息认证、文件校验等多个场景。然而,考虑到安全因素,MD5和SHA1在新项目中已不再推荐...
标题中的“HMac.rar_hmac”表明这是一个关于HMAC(Hash-based Message Authentication Code)的压缩文件,其中可能包含了实现HMAC算法的Java源代码。HMAC是一种基于哈希函数的安全机制,用于验证数据的完整性和来源...
在Java中,常见的单向加密算法包括MD5(Message-Digest Algorithm 5)、SHA(Secure Hash Algorithm)系列以及HMAC(Hash-based Message Authentication Code)。 **BASE64编码** 虽然BASE64不是真正的加密算法,...
Java提供了HMAC(Hash-based Message Authentication Code)类,如HMAC-MD5和HMAC-SHA。 5. **数字签名** 数字签名利用非对称加密技术,能验证数据的完整性和发送者的身份。Java提供Signature类支持RSA、DSA等数字...
常见的加密算法实现--Java语言编写,花费一个多月认真整理出来的可直接运行的源码文件。下载RAR文件后,对压缩包进行解压后,里面有详细的例子,导入IDEA或者ECLIPSE后,运行指定的Java文件,即可以直接使用。压缩包...
本文将详细讲解Java中MD5加密的原理、步骤以及实现方法。 ### MD5加密原理 MD5算法由Ronald Rivest于1991年设计,它将任意长度的信息映射为一个128位(16字节)的摘要,通常用32个十六进制数字表示。MD5具有抗碰撞...