youxixingzhet 发表于 2022-3-20 22:50:34

救命啊 救救孩子吧

#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里是三十二个字符 还是十六个字节???

傻眼貓咪 发表于 2022-3-21 08:22:59

Q1: 因为 MD5 从不等长度数据变成固定长度数据 512bits,再加上 MD5 演算,极其复杂,我知道其原理,但不知如何弄(因为一直需要转换),抱歉帮不到你。而且你的头文件 md5.h 应该不是标准库吧,没有完整代码更是难判断问题所在。

注:MD5 输入的数据必须预处理长度为512bits,其中448bits 为明文 + padding,64bits 为明文长度。

Q2: MD5 128bits = 16字节(128/8)

youxixingzhet 发表于 2022-3-21 08:46:24

傻眼貓咪 发表于 2022-3-21 08:22
Q1: 因为 MD5 从不等长度数据变成固定长度数据 512bits,再加上 MD5 演算,极其复杂,我知道其原理,但不知 ...

感觉第一个问题是把dest里的十六个字节放入temp1里然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句话又把temp1里十六个字节中的八个字节放进temp2里   那为什么temp2里的八个字节变成了十六个字符呢 难道在数组里他会自动分配吗?

傻眼貓咪 发表于 2022-3-21 10:47:43

youxixingzhet 发表于 2022-3-21 08:46
感觉第一个问题是把dest里的十六个字节放入temp1里然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句 ...

哈哈,{:10_266:}{:10_266:} 这就是我觉得困难的点,我只知道MD5原理,算法公式也有,就是不会转换长度(bits)

傻眼貓咪 发表于 2022-3-21 10:51:58

youxixingzhet 发表于 2022-3-21 08:46
感觉第一个问题是把dest里的十六个字节放入temp1里然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句 ...

你这个应该是将 512bits 数据拆分成 16 区块 32bits 吧

youxixingzhet 发表于 2022-3-21 13:44:55

傻眼貓咪 发表于 2022-3-21 10:51
你这个应该是将 512bits 数据拆分成 16 区块 32bits 吧

{:9_238:} 我也就是这里没有弄懂

傻眼貓咪 发表于 2022-3-21 13:46:57

youxixingzhet 发表于 2022-3-21 13:44
我也就是这里没有弄懂

{:10_257:}{:10_257:}
页: [1]
查看完整版本: 救命啊 救救孩子吧