目录
一、MD5算法
二、SHA-256算法
三、MD5算法和SHA-256 比较
一、MD5算法
1、MD5简介:
(1)MD5算法是一种哈希算法,用于将任意长度的消息压缩成固定长度的消息摘要(通常为128位)。它是由美国密码学家罗纳德·李维斯特(Ronald L. Rivest)在1991年发明的。
(2)MD5算法的基本思想是将原始消息分成若干个固定大小的块,对每个块进行处理,最终将所有块的处理结果合并成一个128位的消息摘要。具体的处理过程包括填充、分组、四轮循环和合并四个字节。
(3)MD5算法被广泛应用于数字签名、文件完整性校验、密码学等领域。然而,由于其安全性较低,已被一些更安全的哈希算法如SHA-256取代。
2、MD5算法 C++源码实现
//以下是C++代码实现MD5算法:
#include <iostream>
#include <cstring>
#include <cstdint>
using namespace std;
const uint32_t S[64] = {
7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22,
5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20,
4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23,
6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21
};
const uint32_t K[64] = {
0xd76aa478, 0xe8c7b756, 0x242070db, 0xc1bdceee,
0xf57c0faf, 0x4787c62a, 0xa8304613, 0xfd469501,
0x698098d8, 0x8b44f7af, 0xffff5bb1, 0x895cd7be,
0x6b901122, 0xfd987193, 0xa679438e, 0x49b40821,
0xf61e2562, 0xc040b340, 0x265e5a51, 0xe9b6c7aa,
0xd62f105d, 0x2441453, 0xd8a1e681, 0xe7d3fbc8,
0x21e1cde6, 0xc33707d6, 0xf4d50d87, 0x455a14ed,
0xa9e3e905, 0xfcefa3f8, 0x676f02d9, 0x8d2a4c8a,
0xfffa3942, 0x8771f681, 0x6d9d6122, 0xfde5380c,
0xa4beea44, 0x4bdecfa9, 0xf6bb4b60, 0xbebfbc70,
0x289b7ec6, 0xeaa127fa, 0xd4ef3085, 0x4881d05,
0xd9d4d039, 0xe6db99e5, 0x1fa27cf8, 0xc4ac5665,
0xf4292244, 0x432aff97, 0xab9423a7, 0xfc93a039,
0x655b59c3, 0x8f0ccc92, 0xffeff47d, 0x85845dd1,
0x6fa87e4f, 0xfe2ce6e0, 0xa3014314, 0x4e0811a1,
0xf7537e82, 0xbd3af235, 0x2ad7d2bb, 0xeb86d391
};
uint32_t A, B, C, D;
inline uint32_t leftrotate(uint32_t x, uint32_t c) {
return (x << c) | (x >> (32 - c));
}
void md5_process(uint32_t* block) {
uint32_t a = A, b = B, c = C, d = D;
for (int i = 0; i < 64; ++i) {
uint32_t f, g;
if (i < 16) {
f = (b & c) | ((~b) & d);
g = i;
}
else if (i < 32) {
f = (d & b) | ((~d) & c);
g = (5 * i + 1) % 16;
}
else if (i < 48) {
f = b ^ c ^ d;
g = (3 * i + 5) % 16;
}
else {
f = c ^ (b | (~d));
g = (7 * i) % 16;
}
f += a + K[i] + block[g];
a = d;
d = c;
c = b;
b += leftrotate(f, S[i]);
}
A += a;
B += b;
C += c;
D += d;
}
void md5_hash(const char* msg, uint32_t len) {
A = 0x67452301;
B = 0xefcdab89;
C = 0x98badcfe;
D = 0x10325476;
uint32_t block[16];
int i;
for (i = 0; i + 63 < len; i += 64) {
memcpy(block, msg + i, 64);
md5_process(block);
}
uint32_t rem = len - i;
memcpy(block, msg + i, rem);
block[rem++] = 0x80;
if (rem > 56) {
memset(block + rem, 0, 64 - rem);
md5_process(block);
rem = 0;
}
memset(block + rem, 0, 56 - rem);
len <<= 3;
block[14] = len & 0xffffffff;
block[15] = len >> 32;
md5_process(block);
}
int main() {
char msg[] = "hello world";
md5_hash(msg, strlen(msg));
printf("%08x%08x%08x%08x\n", A, B, C, D);
return 0;
}
3、MD5用qt实现
在Qt中实现MD5算法,可以使用QCryptographicHash类。该类提供了多种加密算法,包括MD5,SHA-1,SHA-256等。
#include <QtCore/QCoreApplication>
#include <QtCore/QDebug>
#include <QtCore/QCryptographicHash>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QString str = "hello world";
QByteArray data = str.toUtf8();
QCryptographicHash hash(QCryptographicHash::Md5);
hash.addData(data);
QByteArray result = hash.result();
QString md5 = result.toHex();
qDebug() << "MD5:" << md5;
return a.exec();
}
该示例将字符串"hello world"转换为UTF-8编码的字节数组,并使用QCryptographicHash类计算MD5值。最后将计算结果转换为十六进制字符串并输出到控制台。
需要注意的是,QCryptographicHash类的addData()函数可以多次调用,以便在多个数据块上执行哈希计算。在计算完最后一个数据块后,必须调用result()函数获取计算结果。
二、SHA-256算法
1、SHA-256简介
(1)SHA-256是一种加密哈希函数,它将任意长度的输入消息转换为一个固定长度的输出值,通常为256位二进制数。SHA-256是美国国家标准技术研究所(NIST)发布的SHA-2家族中的一员,是SHA-224、SHA-384和SHA-512的缩小版本。
(2)SHA-256的安全性主要基于它的抗碰撞性,即对于不同的输入消息,SHA-256产生的哈希值应该是不同的,且无法通过已知的攻击方式找到两个具有相同哈希值的输入消息。SHA-256通常用于数字签名、消息认证、密码学协议和安全通信等领域。
(3)SHA-256的计算复杂度很高,因此可以提供较高的安全性保障。但是,SHA-256也不是绝对安全的,随着计算技术和攻击技术的发展,可能会出现新的攻击方式,因此需要不断更新和改进哈希函数算法。
2、sha-256用qt实现
#include <QtCore/QCoreApplication>
#include <QtCore/QString>
#include <QtCore/QDebug>
#include <QtCore/QByteArray>
#include <QtCore/QCryptographicHash>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QString input = "hello world";
QByteArray data = input.toUtf8();
QByteArray hash = QCryptographicHash::hash(data, QCryptographicHash::Sha256);
QString result = QString(hash.toHex());
qDebug() << "SHA-256 hash of " << input << ": " << result;
return a.exec();
}
在这个示例中,我们使用QCryptographicHash
类来计算SHA-256哈希值。我们首先将输入字符串转换为QByteArray
格式,然后使用QCryptographicHash::hash()
函数计算哈希值。最后,我们将哈希值转换为十六进制字符串,并输出到控制台。
注意,此示例仅用于演示如何在Qt中实现SHA-256算法。在实际应用中,应该采用更安全的哈希算法,并使用适当的哈希参数和盐值来增加安全性。
3、通过导入hashlib 库,使用SHA-256
// 1. 导入 hashlib 库
import hashlib
// 2. 创建一个 SHA - 256 对象
sha256 = hashlib.sha256()
// 3. 将需要哈希的数据传递给 SHA - 256 对象
sha256.update(b"Hello, World!")
// 4. 获取 SHA - 256 哈希值
hash_value = sha256.digest()
// 5. 可以将哈希值转换为十六进制字符串进行存储或传输
hex_value = hash_value.hex()
// 完整示例代码:
import hashlib
sha256 = hashlib.sha256()
sha256.update(b"Hello, World!")
hash_value = sha256.digest()
hex_value = hash_value.hex()
print(hex_value)
// 输出:b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
三、MD5算法和SHA-256 比较
MD5和SHA-256都是常见的哈希算法,用于将任意长度的数据转换为固定长度的哈希值。它们的比较如下:
1. 安全性:SHA-256比MD5更安全。MD5已经被证明存在碰撞攻击,即不同的输入可以生成相同的哈希值,从而导致安全问题。SHA-256则没有这个问题,目前还没有被证明存在碰撞攻击。
2. 哈希值长度:SHA-256的哈希值长度为256位,比MD5的128位更长。这意味着SHA-256的哈希值空间更大,哈希冲突的可能性更小。
3. 计算速度:MD5比SHA-256计算速度更快。但是,这并不意味着MD5更好,因为计算速度越快,越容易受到暴力破解和彩虹表攻击。
4. 应用场景:SHA-256通常用于需要更高安全性的场景,如数字签名、密码学和区块链等,而MD5则适用于需要快速计算哈希值的场景,如文件完整性检查和密码验证等。
综上所述,SHA-256比MD5更安全,但计算速度可能稍慢。在选择哈希算法时,应根据实际应用场景和安全需求进行选择。