iPhone中的SHA256密钥生成器

时间:2010-06-22 13:37:24

标签: iphone objective-c cryptography openssl aes

我想使用带有N次迭代的SHA256生成密钥。

他们的输入应该是我的“密码” + “随机数”

我已经看过苹果提供的加密样本,但它似乎没有提供我的要求(或者可能我没有得到它)​​。

我也经历过以下链接,但是没有使用SHA256生成密钥的方法 http://iphonedevelopment.blogspot.com/2009/02/strong-encryption-for-cocoa-cocoa-touch.html

等待一些提示。

此致

2 个答案:

答案 0 :(得分:1)

试试这个,它对我有用

1)获取平面文本输入的哈希值

-(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;
}

2)获取NSData的哈希作为输入

注意: - 我使用过NSData类别,所以代码如下

- (NSString *)SHA256_HASH {
if (!self) return nil;

unsigned char hash[CC_SHA256_DIGEST_LENGTH];
if ( CC_SHA256([(NSData*)self bytes], [(NSData*)self length], hash) ) {
    NSData *sha2 = [NSData dataWithBytes:hash length:CC_SHA256_DIGEST_LENGTH]; 

    // description converts to hex but puts <> around it and spaces every 4 bytes
    NSString *hash = [sha2 description];
    hash = [hash stringByReplacingOccurrencesOfString:@" " withString:@""];
    hash = [hash stringByReplacingOccurrencesOfString:@"<" withString:@""];
    hash = [hash stringByReplacingOccurrencesOfString:@">" withString:@""];
    // hash is now a string with just the 40char hash value in it
    //NSLog(@"hash = %@",hash);

    // Format SHA256 fingerprint like
    // 00:00:00:00:00:00:00:00:00
    int keyLength=[hash length];
    NSString *formattedKey = @"";
    for (int i=0; i<keyLength; i+=2) {
        NSString *substr=[hash substringWithRange:NSMakeRange(i, 2)];
        if (i!=keyLength-2) 
            substr=[substr stringByAppendingString:@":"];
        formattedKey = [formattedKey stringByAppendingString:substr];
    }

    return formattedKey;
}
return nil;

}

答案 1 :(得分:-1)

Apple论坛上的

This discussion可以帮助你