C++sha1哈希的填充算法
时间: 2023-07-09 11:33:07 浏览: 112
以下是C++实现SHA-1哈希算法填充算法的示例代码:
```c++
#include <iostream>
#include <cstring>
#include <cstdint>
// 填充算法
void padding(uint8_t *message, size_t message_len, uint8_t *padded_message) {
// 将消息复制到填充后的消息中
memcpy(padded_message, message, message_len);
// 添加比特"1"
padded_message[message_len] = 0x80;
// 添加比特"0"直到满足对512取模的余数为448位
size_t padded_len = message_len + 1;
while (padded_len % 64 != 56) {
padded_message[padded_len] = 0x00;
padded_len++;
}
// 添加比特串,表示原始消息的比特长度(64位)
uint64_t bit_len = message_len * 8;
memcpy(padded_message + padded_len, &bit_len, sizeof(bit_len));
}
```
使用方法:
```c++
int main() {
uint8_t message[] = "hello world";
size_t message_len = strlen((char*)message);
size_t padded_len = (message_len + 8 + 64) / 64 * 64;
uint8_t *padded_message = new uint8_t[padded_len];
padding(message, message_len, padded_message);
// ...
delete[] padded_message;
return 0;
}
```
其中,`message`表示要进行哈希计算的消息,`message_len`表示消息的长度,`padded_message`表示填充后的消息。在示例代码中,使用`memcpy`函数将原始消息复制到填充后的消息中,并使用循环添加比特"0",直到满足对512取模的余数为448位。最后,使用`memcpy`函数将表示原始消息的比特长度的64位二进制串添加到填充后的消息末尾。
阅读全文
相关推荐















