QT 中实现HMAC-SHA1
2017-08-12 13:36
260 查看
实现函数:
QString hmacSha1(QByteArray key, QByteArray baseString)
{
int blockSize = 64; // HMAC-SHA-1 block size, defined in SHA-1 standard
if (key.length() > blockSize) { // if key is longer than block size (64), reduce key length with SHA-1 compression
key = QCryptographicHash::hash(key, QCryptographicHash::Sha1);
}
QByteArray innerPadding(blockSize, char(0x36)); // initialize inner padding with char "6"
QByteArray outerPadding(blockSize, char(0x5c)); // initialize outer padding with char "quot;
// ascii characters 0x36 ("6") and 0x5c ("quot;) are selected because they have large
// Hamming distance (http://en.wikipedia.org/wiki/Hamming_distance)
for (int i = 0; i < key.length(); i++) {
innerPadding[i] = innerPadding[i] ^ key.at(i); // XOR operation between every byte in key and innerpadding, of key length
outerPadding[i] = outerPadding[i] ^ key.at(i); // XOR operation between every byte in key and outerpadding, of key length
}
// result = hash ( outerPadding CONCAT hash ( innerPadding CONCAT baseString ) ).toBase64
QByteArray total = outerPadding;
QByteArray part = innerPadding;
part.append(baseString);
total.append(QCryptographicHash::hash(part, QCryptographicHash::Sha1));
QByteArray hashed = QCryptographicHash::hash(total, QCryptographicHash::Sha1);
return hashed.toBase64();
}
转自:QTWIKI
也有人稍有不同的做法:
Qt 实现 HMAC_SHA1 哈希算法
QString hmacSha1(QByteArray key, QByteArray baseString)
{
int blockSize = 64; // HMAC-SHA-1 block size, defined in SHA-1 standard
if (key.length() > blockSize) { // if key is longer than block size (64), reduce key length with SHA-1 compression
key = QCryptographicHash::hash(key, QCryptographicHash::Sha1);
}
QByteArray innerPadding(blockSize, char(0x36)); // initialize inner padding with char "6"
QByteArray outerPadding(blockSize, char(0x5c)); // initialize outer padding with char "quot;
// ascii characters 0x36 ("6") and 0x5c ("quot;) are selected because they have large
// Hamming distance (http://en.wikipedia.org/wiki/Hamming_distance)
for (int i = 0; i < key.length(); i++) {
innerPadding[i] = innerPadding[i] ^ key.at(i); // XOR operation between every byte in key and innerpadding, of key length
outerPadding[i] = outerPadding[i] ^ key.at(i); // XOR operation between every byte in key and outerpadding, of key length
}
// result = hash ( outerPadding CONCAT hash ( innerPadding CONCAT baseString ) ).toBase64
QByteArray total = outerPadding;
QByteArray part = innerPadding;
part.append(baseString);
total.append(QCryptographicHash::hash(part, QCryptographicHash::Sha1));
QByteArray hashed = QCryptographicHash::hash(total, QCryptographicHash::Sha1);
return hashed.toBase64();
}
转自:QTWIKI
也有人稍有不同的做法:
Qt 实现 HMAC_SHA1 哈希算法
相关文章推荐
- Qt 实现 HMAC_SHA1 哈希算法
- Qt 中实现 hmac Sha1 加密并以 base64编码输出
- [绍棠_Swift] Swift4.0如何实现字符串的HMAC_SHA1加密
- HMAC-SHA1的php实现
- java 实现 hmac_sha1加密
- Python对PHP服务器hmac_sha1签名认证方法的匹配实现
- HMAC-SHA1各语言版本实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现
- HMAC-SHA1 BASE64编码 java源代码实现
- HMAC_SHA1加密-PKCS5_PBKDF2_HMAC_SHA1的方法实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现 的另一种方式
- snooper taoism中分步编写实现sha1_hmac
- HMAC-SHA1各语言版本实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现
- Android HMAC_SHA1 算法简单实现
- Swift - 如何实现字符串的HMAC_SHA1加密
- Java实现HmacSHA1加密
- HMAC-SHA1的java源代码实现
- OAuth认证的 HMAC-SHA1签署 实现