6

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

就像是:

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

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

非常感谢您的帮助

4

2 回答 2

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.

于 2011-09-24T17:31:28.533 回答
1

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

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

看起来,它从 /dev/random 读取 100 个字节。详情请参阅man urandom

于 2014-01-26T17:49:53.533 回答