暗号化のためにファイルに追加するランダムデータを生成する必要があります。どうすればこれを行うことができますか?ランダムな文字列を生成するのと同じような考えでしょうか?
何かのようなもの:
NSData *randomData = @"what should i put here?";
次に、rand()関数を使用してデータをランダム化しますか?
あなたの助けは大歓迎です
暗号化のためにファイルに追加するランダムデータを生成する必要があります。どうすればこれを行うことができますか?ランダムな文字列を生成するのと同じような考えでしょうか?
何かのようなもの:
NSData *randomData = @"what should i put here?";
次に、rand()関数を使用してデータをランダム化しますか?
あなたの助けは大歓迎です
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
。
UNIXでは、/ dev/randomまたは/dev/ urandomを使用して、暗号品質のランダム性を取得できます。
NSData *bytes = [[NSFileHandle fileHandleForReadingAtPath: @"/dev/random"] readDataOfLength: 100];
どうやら、/ dev/randomから100バイトを読み取ります。詳細はを参照しman urandom
てください。