美文网首页
NSData MD5加密的坑

NSData MD5加密的坑

作者: 点点_星光 | 来源:发表于2020-09-01 21:32 被阅读0次

    MD5加密方法

    + (NSString *)getMD5WithData:(NSData *)data {
        const char* original_str = (const char *)[data bytes];
        unsigned char digist[CC_MD5_DIGEST_LENGTH]; //CC_MD5_DIGEST_LENGTH = 16
        CC_MD5(original_str, (uint)strlen(original_str), digist);
        NSMutableString *outPutStr = [NSMutableString stringWithCapacity:10];
        for (int  i =0; i<CC_MD5_DIGEST_LENGTH;i++){
            [outPutStr appendFormat:@"%02x",digist[i]];//小写x表示输出的是小写MD5,大写X表示输出的是大写MD5
        }
        return [outPutStr lowercaseString];
    }
    

    这个加密方法在有些时候(一个字符串类型且带空格)就会加密错误,原因当data中某个字节的内容为<00>,在字符数组中为"\0",所以算出的长度不对。解决办法可参考这个大兄弟的文章https://blog.csdn.net/qq_28699375/article/details/83501239(ps:我没去试过)
    面对NSData加密的时候我选择用另一种方法加密

    + (NSString *)getMD5WithData:(NSData *)data {
        //1: 创建一个MD5对象
        CC_MD5_CTX md5;
        //2: 初始化MD5
        CC_MD5_Init(&md5);
        //3: 准备MD5加密
        CC_MD5_Update(&md5, data.bytes, (uint32_t)data.length);
        //4: 准备一个字符串数组, 存储MD5加密之后的数据
        unsigned char result[CC_MD5_DIGEST_LENGTH];
        //5: 结束MD5加密
        CC_MD5_Final(result, &md5);
        NSMutableString *resultString = [NSMutableString string];
        //6:从result数组中获取最终结果
        for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
          [resultString appendFormat:@"%02x", result[i]];
        }
        return resultString;
    }
    

    这个方法好处是不用data.bytes强转成const char *,有点怕了,然后长度也可以用data.length得出精确地值。(一般MD5加密失败都是长度不对导致的)

    相关文章

      网友评论

          本文标题:NSData MD5加密的坑

          本文链接:https://www.haomeiwen.com/subject/hsdbsktx.html