Rfc2898DeriveBytes.GetBytes メソッド
アセンブリ: mscorlib (mscorlib.dll 内)

Dim instance As Rfc2898DeriveBytes Dim cb As Integer Dim returnValue As Byte() returnValue = instance.GetBytes(cb)
戻り値
擬似ランダム キー バイトを格納したバイト配列。

Rfc2898DeriveBytes クラスは、HMACSHA1 に基づく擬似乱数ジェネレータを使用して PBKDF2 機能を実装します。Rfc2898DeriveBytes クラスは引数として、パスワード、salt、反復回数を受け取り、GetBytes メソッドを呼び出してキーを生成します。このメソッドを繰り返し呼び出しても同じキーは生成されません。GetBytes メソッドを 20 の cb パラメータ値で 2 回呼び出すことは、GetBytes メソッドを 40 の cb パラメータ値で 1 回呼び出すことに相当します。

Rfc2898DeriveBytes クラスを使用して、TripleDES クラスのまったく同じ 2 つのキーを作成するコード例を次に示します。次に、このキーを使用して、一部のデータを暗号化および復号化します。
try { Rfc2898DeriveBytes k1 = new Rfc2898DeriveBytes(pwd1, salt1 ,myIterations); Rfc2898DeriveBytes k2 = new Rfc2898DeriveBytes(pwd1, salt1); // Encrypt the data. TripleDES encAlg = TripleDES.Create(); encAlg.Key = k1.GetBytes(16); MemoryStream encryptionStream = new MemoryStream(); CryptoStream encrypt = new CryptoStream(encryptionStream, encAlg.CreateEncryptor(),CryptoStreamMode.Write); byte[] utfD1 = new System.Text.UTF8Encoding(false).GetBytes(data1);
try { Rfc2898DeriveBytes ^ k1 = gcnew Rfc2898DeriveBytes( pwd1,salt1,myIterations ); Rfc2898DeriveBytes ^ k2 = gcnew Rfc2898DeriveBytes( pwd1,salt1 ); // Encrypt the data. TripleDES^ encAlg = TripleDES::Create(); encAlg->Key = k1->GetBytes( 16 ); MemoryStream^ encryptionStream = gcnew MemoryStream; CryptoStream^ encrypt = gcnew CryptoStream( encryptionStream,encAlg->CreateEncryptor(),CryptoStreamMode::Write ); array<Byte>^utfD1 = (gcnew System::Text::UTF8Encoding( false ))->GetBytes( data1 );
try { Rfc2898DeriveBytes k1 = new Rfc2898DeriveBytes(pwd1, salt1 , myIterations); Rfc2898DeriveBytes k2 = new Rfc2898DeriveBytes(pwd1, salt1); // Encrypt the data. TripleDES encAlg = TripleDES.Create(); encAlg.set_Key(k1.GetBytes(16)); MemoryStream encryptionStream = new MemoryStream(); CryptoStream encrypt = new CryptoStream(encryptionStream, encAlg.CreateEncryptor(), CryptoStreamMode.Write); ubyte utfD1[] = (new System.Text.UTF8Encoding(false)). GetBytes(data1);

Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


- Rfc2898DeriveBytes.GetBytes メソッドのページへのリンク