安全服务API似乎不允许我直接计算散列.有很多公共领域和自由许可的版本可用,但如果可能的话,我宁愿使用系统库实现.
可以通过NSData或普通指针访问数据.
哈希的加密强度对我很重要.SHA-256是可接受的最小哈希大小.
安全服务API似乎不允许我直接计算散列.有很多公共领域和自由许可的版本可用,但如果可能的话,我宁愿使用系统库实现.
可以通过NSData或普通指针访问数据.
哈希的加密强度对我很重要.SHA-256是可接受的最小哈希大小.
这是我在SHA1中使用的:
#import <CommonCrypto/CommonDigest.h>
+ (NSData *)sha1:(NSData *)data {
unsigned char hash[CC_SHA1_DIGEST_LENGTH];
if ( CC_SHA1([data bytes], [data length], hash) ) {
NSData *sha1 = [NSData dataWithBytes:hash length:CC_SHA1_DIGEST_LENGTH];
return sha1;
}
return nil;
}
将CC_SHA1
替换为CC_SHA256
(或任何你需要的),将CC_SHA1_DIGEST_LENGTH
替换为CC_SHA256_DIGEST_LENGTH
.