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];
}
這個(gè)加密方法在有些時(shí)候(一個(gè)字符串類型且?guī)Э崭?就會(huì)加密錯(cuò)誤,原因當(dāng)data中某個(gè)字節(jié)的內(nèi)容為<00>,在字符數(shù)組中為"\0",所以算出的長(zhǎng)度不對(duì)。解決辦法可參考這個(gè)大兄弟的文章https://blog.csdn.net/qq_28699375/article/details/83501239
(ps:我沒(méi)去試過(guò))
面對(duì)NSData加密的時(shí)候我選擇用另一種方法加密
+ (NSString *)getMD5WithData:(NSData *)data {
//1: 創(chuàng)建一個(gè)MD5對(duì)象
CC_MD5_CTX md5;
//2: 初始化MD5
CC_MD5_Init(&md5);
//3: 準(zhǔn)備MD5加密
CC_MD5_Update(&md5, data.bytes, (uint32_t)data.length);
//4: 準(zhǔn)備一個(gè)字符串?dāng)?shù)組, 存儲(chǔ)MD5加密之后的數(shù)據(jù)
unsigned char result[CC_MD5_DIGEST_LENGTH];
//5: 結(jié)束MD5加密
CC_MD5_Final(result, &md5);
NSMutableString *resultString = [NSMutableString string];
//6:從result數(shù)組中獲取最終結(jié)果
for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
[resultString appendFormat:@"%02x", result[i]];
}
return resultString;
}
這個(gè)方法好處是不用data.bytes強(qiáng)轉(zhuǎn)成const char *,有點(diǎn)怕了,然后長(zhǎng)度也可以用data.length得出精確地值。(一般MD5加密失敗都是長(zhǎng)度不對(duì)導(dǎo)致的)