|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 小坛砸 于 2025-8-8 09:43 编辑
文选自《带你学C带你飞》(语法篇)S1E30: 指针函数和函数指针 | 课后测试题 动动手1
我想问问在加盐函数salt中,为什么要先用temp2存一次再使用strncap连接?能不能直接用snprintf把原输入字符串和md5的中间16位连接起来呢?
我在做题时直接使用snprintf将第一次输入的密码和md5加密后的字符串进行连接
- int n = 0;
- char strAdd[100];//存储连接后的字符串
- strcpy(strAdd,encrypt);//encrypt是输入的密码字符串
- char *p = strAdd+strlen(encrypt);
- for(int i = 0;i < 16; i++){
- n = snprintf(p+i*2,"%02x",decrypt+i+4);//decrypt是md5第一次加密后的字符串
- }
- printf("buff:%s, n:%d\n",strAdd,n);//这里打印出来后,在输入的密码之后的字符串乱码
复制代码 输出结果在附件图片(不知道怎么放在这个地方 )
课后答案代码
- #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)
- {
- int i;
- 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;
- }
复制代码 |
-
|