Qt 实现 HMAC_SHA1 哈希算法
来源:互联网 发布:面向对象编程什么意思 编辑:程序博客网 时间:2024/05/16 06:50
Qt哈希算法 hmacSha1
//Qt哈希算法 hmacSha1#include <QCryptographicHash> /*! * \brief Qt hmacSha1 哈希算法 * \param key 加密需要的key * \param baseString 需要加密的字符串 * \return QByteArray 加密后的数据内存中的ASCII码 */QByteArray 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 "/" // ascii characters 0x36 ("6") and 0x5c ("/") 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); /// 注意——>把字符串hashed转换为Hex,内存中的ASCII码arrayFromHexString QByteArray arrayFromHexString = QByteArray::fromHex(hashed.toHex()); qDebug()<<"hmacSha1内存中的ASCII码 arrayFromHexString \n"<<arrayFromHexString.toHex(); return arrayFromHexString;}
阅读全文
0 0
- Qt 实现 HMAC_SHA1 哈希算法
- Android HMAC_SHA1 算法简单实现
- BCB实现 Hmac_sha1算法源码
- PHP 的 HMAC_SHA1算法 实现
- java 实现 hmac_sha1加密
- Java的HMAC_SHA1算法源码
- HMAC_SHA1加密-PKCS5_PBKDF2_HMAC_SHA1的方法实现
- MD5算法Qt实现
- [绍棠_Swift] Swift4.0如何实现字符串的HMAC_SHA1加密
- hmac_sha1 签名
- qt 实现md5 算法加密
- Python对PHP服务器hmac_sha1签名认证方法的匹配实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现 的另一种方式
- Java对PHP服务器hmac_sha1签名认证方法的匹配实现
- AES加解密算法Qt实现
- DES加解密算法Qt实现
- abstract
- Java写邮件发送
- STM32入门开发--按键模块实现按键点灯
- 40 矩阵键盘在linux内核里的驱动实现
- oralce修改表空间为自动扩展
- Qt 实现 HMAC_SHA1 哈希算法
- SDL2.0 使用互斥量
- AfxGetApp用法
- apt-get install 下载太慢怎么办,用apt-fast!
- springMVC-参数绑定(服务器接收页面传来的参数)返回值转换为JSON
- TCP套接字(server/client实现)
- ZStack(CC2530) 断电存储(NV)方法
- 汇编-字符串小写转大写
- Android 序列化学习总结