Rfc2898DeriveBytes.GetBytes(Int32) Metoda
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Zwraca pseudolosowy klucz dla tego obiektu.
public:
override cli::array <System::Byte> ^ GetBytes(int cb);
public override byte[] GetBytes (int cb);
override this.GetBytes : int -> byte[]
Public Overrides Function GetBytes (cb As Integer) As Byte()
Parametry
- cb
- Int32
Liczba bajtów klucza pseudolosowego do wygenerowania.
Zwraca
Tablica bajtów wypełniona pseudolosowymi bajtami klucza.
Wyjątki
cb
jest poza zakresem. Ten parametr wymaga liczby nieujemnej.
Przykłady
W poniższym przykładzie pokazano, jak za pomocą GetBytes metody pobrać klucz dla wystąpienia klasy Rfc2898DeriveBytes. Ten przykład kodu jest częścią większego przykładu udostępnionego Rfc2898DeriveBytes dla klasy .
try
{
Rfc2898DeriveBytes ^ k1 = gcnew Rfc2898DeriveBytes( pwd1,salt1,myIterations );
Rfc2898DeriveBytes ^ k2 = gcnew Rfc2898DeriveBytes( pwd1,salt1 );
// Encrypt the data.
Aes^ encAlg = Aes::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.
Aes encAlg = Aes.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
Dim k1 As New Rfc2898DeriveBytes(pwd1, salt1, myIterations)
Dim k2 As New Rfc2898DeriveBytes(pwd1, salt1)
' Encrypt the data.
Dim encAlg As Aes = Aes.Create()
encAlg.Key = k1.GetBytes(16)
Dim encryptionStream As New MemoryStream()
Dim encrypt As New CryptoStream(encryptionStream, encAlg.CreateEncryptor(), CryptoStreamMode.Write)
Dim utfD1 As Byte() = New System.Text.UTF8Encoding(False).GetBytes(data1)
Uwagi
Klasa Rfc2898DeriveBytes implementuje funkcje PBKDF2 przy użyciu generatora liczb pseudorandom w oparciu o HMACSHA1. Klasa Rfc2898DeriveBytes przyjmuje hasło, sól i liczbę iteracji, a następnie generuje klucze za pomocą wywołań metody GetBytes . Powtarzające się wywołania tej metody nie będą generować tego samego klucza; Zamiast tego dołączanie dwóch wywołań GetBytes metody z wartością cb
parametru 20
jest odpowiednikiem wywołania GetBytes metody raz z wartością cb
parametru 40
.