NSData MD5加密的坑

2020-09-01  本文已影响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加密失败都是长度不对导致的)

上一篇 下一篇

猜你喜欢

热点阅读