+ (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的参数,进行MD5,得到字符串。但是得到的数据是错误的。
问题在于[data bytes],将data转成字符数组的时候,当data中某个字节的内容为<00>时,该字节在数组中的内容为:"\0",然后在后续的加密过程中有一个C函数:strlen,所以在算该字节数组长度的时候,一但碰到"\0",就被当做结束符处理了,所以导致长度不对,从而使得MD5之后得到的数据错误。
所以解决办法就是
CC_MD5(original_str, 8, digist);//固定8个字节 因为我的data参数长度是固定8个字节的,所以这个地方的参数直接填8就ok了,如果长度不确定, 可以把这个计算长度的方法改掉例如改成:[data length],或者用字符串处理也是一样的,主要是要确保长度正确。