鱼C论坛

 找回密码
 立即注册
查看: 857|回复: 6

救命啊 救救孩子吧

[复制链接]
发表于 2022-3-20 22:50:34 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#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[16]; // 存储原始数据第一次计算MD5的值
        unsigned char temp2[16]; // 存储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[i]);
        }

        length = strlen(src);

        strncpy(mix, src, length);
        strncat(mix, temp2, 16);

        mix[length + 16 + 1] = '\0';
}

int main(void)
{
        int i;
        unsigned char src[LIMIT];
        unsigned char mix[LIMIT + 16];
        unsigned char dest[16];

        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[i]);
        }
        putchar('\n');

        return 0;
}

Q1:
snprintf(temp2 + 2*j, 16, "%02x", temp1[i])
这句话为什么temp1每次进一个字节长度 而放进temp2里面却每次进两个字节长度呢??????是真想不明白


Q2:
MD5函数加密后存放在dest里是三十二个字符 还是十六个字节???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

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

Q2: MD5 128bits = 16字节(128/8)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 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里的八个字节变成了十六个字符呢 难道在数组里他会自动分配吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-21 10:47:43 From FishC Mobile | 显示全部楼层
youxixingzhet 发表于 2022-3-21 08:46
感觉第一个问题是把dest里的十六个字节放入temp1里  然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句 ...

哈哈, 这就是我觉得困难的点,我只知道MD5原理,算法公式也有,就是不会转换长度(bits)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-21 10:51:58 From FishC Mobile | 显示全部楼层
youxixingzhet 发表于 2022-3-21 08:46
感觉第一个问题是把dest里的十六个字节放入temp1里  然后 snprintf(temp2 + 2*j, 16, "%02x", temp1)这句 ...

你这个应该是将 512bits 数据拆分成 16 区块 32bits 吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-21 13:44:55 | 显示全部楼层
傻眼貓咪 发表于 2022-3-21 10:51
你这个应该是将 512bits 数据拆分成 16 区块 32bits 吧

我也就是这里没有弄懂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-21 13:46:57 From FishC Mobile | 显示全部楼层
youxixingzhet 发表于 2022-3-21 13:44
我也就是这里没有弄懂

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-18 04:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表