我需要生成一些随机数据附加到我的文件进行加密。我该怎么做呢?它是否与生成一串随机字符的想法相同?
类似的东西:
NSData *randomData = @"what should i put here?";
然后使用rand()函数随机化数据?
非常感谢您的帮助
答案 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
。