救命啊 救救孩子吧
#include <stdio.h>#include <string.h>
#include "md5.h"
#define LIMIT 128
void md5(unsigned char *dest, unsigned char *src);
void salt(unsigned char *mix, unsigned char *src);
void md5(unsigned char *dest, unsigned char *src)
{
MD5_CTX md5;
// 初始化
MD5Init(&md5);
// 传入明文字符串及其长度
MD5Update(&md5, src, strlen((char *)src));
// 得到加密后的字符串
MD5Final(&md5, dest);
}
void salt(unsigned char *mix, unsigned char *src)
{
unsigned char temp1; // 存储原始数据第一次计算MD5的值
unsigned char temp2; // 存储temp1中间16位为字符串
int i, j, length;
md5(temp1, src);
for (i = 4, j = 0; i < 12; i++, j++)
{
snprintf(temp2 + 2*j, 16, "%02x", temp1);
}
length = strlen(src);
strncpy(mix, src, length);
strncat(mix, temp2, 16);
mix = '\0';
}
int main(void)
{
int i;
unsigned char src;
unsigned char mix;
unsigned char dest;
printf("请输入密码:");
scanf("%s", src);
printf("你输入的密码是:%s\n", src);
salt(mix, src);
printf("加盐后的密码是:%s\n", mix);
md5(dest, mix);
printf("加密后的密码是:");
for (i = 0; i < 16; i++)
{
printf("%02x", dest);
}
putchar('\n');
return 0;
}
Q1:
snprintf(temp2 + 2*j, 16, "%02x", temp1)
这句话为什么temp1每次进一个字节长度 而放进temp2里面却每次进两个字节长度呢??????是真想不明白
Q2:
MD5函数加密后存放在dest里是三十二个字符 还是十六个字节??? Q1: 因为 MD5 从不等长度数据变成固定长度数据 512bits,再加上 MD5 演算,极其复杂,我知道其原理,但不知如何弄(因为一直需要转换),抱歉帮不到你。而且你的头文件 md5.h 应该不是标准库吧,没有完整代码更是难判断问题所在。
注:MD5 输入的数据必须预处理长度为512bits,其中448bits 为明文 + padding,64bits 为明文长度。
Q2: MD5 128bits = 16字节(128/8) 傻眼貓咪 发表于 2022-3-21 08:22
Q1: 因为 MD5 从不等长度数据变成固定长度数据 512bits,再加上 MD5 演算,极其复杂,我知道其原理,但不知 ...
感觉第一个问题是把dest里的十六个字节放入temp1里然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句话又把temp1里十六个字节中的八个字节放进temp2里 那为什么temp2里的八个字节变成了十六个字符呢 难道在数组里他会自动分配吗? youxixingzhet 发表于 2022-3-21 08:46
感觉第一个问题是把dest里的十六个字节放入temp1里然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句 ...
哈哈,{:10_266:}{:10_266:} 这就是我觉得困难的点,我只知道MD5原理,算法公式也有,就是不会转换长度(bits) youxixingzhet 发表于 2022-3-21 08:46
感觉第一个问题是把dest里的十六个字节放入temp1里然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句 ...
你这个应该是将 512bits 数据拆分成 16 区块 32bits 吧 傻眼貓咪 发表于 2022-3-21 10:51
你这个应该是将 512bits 数据拆分成 16 区块 32bits 吧
{:9_238:} 我也就是这里没有弄懂 youxixingzhet 发表于 2022-3-21 13:44
我也就是这里没有弄懂
{:10_257:}{:10_257:}
页:
[1]