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加密失败都是长度不对导致的)
网友评论