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が指摘しているように、SecRandomCopyBytesを使用できるようにするには、Security.frameworkをリンクする必要があります。また、を含める必要があります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 に答える