我有一个生成字符串的 sha256 加密的函数,
这是功能:
-(NSString*)sha256HashFor:(NSString*)input
{
const char* str = [input UTF8String];
unsigned char result[CC_SHA256_DIGEST_LENGTH];
CC_SHA256(str, strlen(str), result);
NSMutableString *ret = [NSMutableString stringWithCapacity:CC_SHA256_DIGEST_LENGTH*2];
for(int i = 0; i<CC_SHA256_DIGEST_LENGTH; i++)
{
[ret appendFormat:@"%02x",result[i]];
}
return ret;
}
现在这条线CC_SHA256(str, strlen(str), result);
就是产生这个警告的原因(警告是针对 strlen(str) 变量的)。
Implicit conversion loses integer precision: 'size_t' (aka 'unsigned long') to 'CC_LONG' (aka 'unsigned int')
我猜我只需要将 strlen(str) 转换为 CC_Long,但我不知道该怎么做。