生成随机字节Cocoa?

时间:2011-09-24 17:29:43

标签: cocoa encryption byte initialization-vector

我需要生成一些随机数据附加到我的文件进行加密。我该怎么做呢?它是否与生成一串随机字符的想法相同?

类似的东西:

NSData *randomData = @"what should i put here?";

然后使用rand()函数随机化数据?

非常感谢您的帮助

2 个答案:

答案 0 :(得分:14)

int SecRandomCopyBytes ( SecRandomRef rnd, size_t count, uint8_t *bytes );

例如:

uint8_t data[100];
int err = 0;

// Don't ask for too many bytes in one go, that can lock up your system
err = SecRandomCopyBytes(kSecRandomDefault, 100, data);
if(err != noErr)
    @throw [NSException exceptionWithName:@"..." reason:@"..." userInfo:nil];

NSData* randomData = [[NSData alloc] initWithBytes:data length:100];

正如彼得在评论中所指出的,你也可以这样做:

NSMutableData* data = [NSMutableData dataWithLength:100];
err = SecRandomCopyBytes(kSecRandomDefault, 100, [data mutableBytes]);

正如Rob在评论中所指出的,您需要链接Security.framework以使SecRandomCopyBytes可用。您还需要包含SecRandom.h

答案 1 :(得分:1)

在UNIX上,您可以依赖/ dev / random或/ dev / urandom来获取加密质量的随机性。

NSData *bytes = [[NSFileHandle fileHandleForReadingAtPath: @"/dev/random"] readDataOfLength: 100];

看起来,它从/ dev / random读取100个字节。有关详细信息,请参阅man urandom