| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
x
 
 本帖最后由 学C的大叔 于 2021-3-6 19:45 编辑  
 
请问下面程序中的   
  for (i = 4, j = 0; i < 12; i++, j++) 
        { 
                snprintf(temp2 + 2*j, 16, "%02x", temp1[i]); 
        } 
这一段如何理解?为什么是temp2 + 2*j? 
temp1 是第一次计算的MD5值,32位字符存放在16字节的字符串temp1[16]中,相当于每个数组元素存放2位字符,现在要取出中间的16位字符,所以从temp1[4]开始取值到temp1[11]结束,那temp2[8]就应该够了吧,为什么要temp2[16]? 
snprintf函数不是只能读取size - 1的字符,那按照上面的写法,不是只能写入15个字符了? 
        length = strlen(src); 
 
        strncpy(mix, src, length); 
        strncat(mix, temp2, 16); 
 
        mix[length + 16 + 1] = '\0'; 
这一部分似乎有点问题,需要加上一句,改成下面这样就正常了,这是为什么啊? 
        length = strlen(src); 
 
        strncpy(mix, src, length); 
        mix[length] = '\0'; 
        strncat(mix, temp2, 16); 
 
        mix[length + 16 + 1] = '\0'; 
 
 
#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; 
} |   
 
 
 
 |