SymmetricAlgorithm.CreateEncryptor Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Vytvoří objekt symetrického encryptoru.
Přetížení
CreateEncryptor() |
Vytvoří objekt symetrického encryptoru s aktuální Key vlastností a inicializačním vektorem (IV). |
CreateEncryptor(Byte[], Byte[]) |
Při přepsání v odvozené třídě vytvoří objekt symetrického encryptoru se zadanou Key vlastností a inicializačním vektorem (IV). |
CreateEncryptor()
- Zdroj:
- SymmetricAlgorithm.cs
- Zdroj:
- SymmetricAlgorithm.cs
- Zdroj:
- SymmetricAlgorithm.cs
public:
virtual System::Security::Cryptography::ICryptoTransform ^ CreateEncryptor();
public virtual System.Security.Cryptography.ICryptoTransform CreateEncryptor ();
abstract member CreateEncryptor : unit -> System.Security.Cryptography.ICryptoTransform
override this.CreateEncryptor : unit -> System.Security.Cryptography.ICryptoTransform
Public Overridable Function CreateEncryptor () As ICryptoTransform
Návraty
Objekt symetrického šifrovače.
Příklady
Následující příklad zašifruje řetězec pomocí objektu transformace vráceného CreateEncryptor z metody .
using namespace System;
using namespace System::Security::Cryptography;
using namespace System::Text;
class EncryptorExample
{
public:
static void Main()
{
TripleDESCryptoServiceProvider^ tdesCSP = gcnew TripleDESCryptoServiceProvider();
tdesCSP->GenerateKey();
tdesCSP->GenerateIV();
String^ quote =
"Things may come to those who wait, but only the " +
"things left by those who hustle. -- Abraham Lincoln";
array<Byte>^ encQuote = EncryptString(tdesCSP, quote);
Console::WriteLine("Encrypted Quote:\n");
Console::WriteLine(Convert::ToBase64String(encQuote));
Console::WriteLine("\nDecrypted Quote:\n");
Console::WriteLine(DecryptBytes(tdesCSP, encQuote));
}
public:
static array<Byte>^ EncryptString(SymmetricAlgorithm^ symAlg, String^ inString)
{
array<Byte>^ inBlock = UnicodeEncoding::Unicode->GetBytes(inString);
ICryptoTransform^ xfrm = symAlg->CreateEncryptor();
array<Byte>^ outBlock = xfrm->TransformFinalBlock(inBlock, 0, inBlock->Length);
return outBlock;
}
static String^ DecryptBytes(SymmetricAlgorithm^ symAlg, array<Byte>^ inBytes)
{
ICryptoTransform^ xfrm = symAlg->CreateDecryptor();
array<Byte>^ outBlock = xfrm->TransformFinalBlock(inBytes, 0, inBytes->Length);
return UnicodeEncoding::Unicode->GetString(outBlock);
}
};
int main()
{
EncryptorExample::Main();
}
using System;
using System.Security.Cryptography;
using System.Text;
class EncryptorExample
{
private static string quote =
"Things may come to those who wait, but only the " +
"things left by those who hustle. -- Abraham Lincoln";
public static void Main()
{
AesCryptoServiceProvider aesCSP = new AesCryptoServiceProvider();
aesCSP.GenerateKey();
aesCSP.GenerateIV();
byte[] encQuote = EncryptString(aesCSP, quote);
Console.WriteLine("Encrypted Quote:\n");
Console.WriteLine(Convert.ToBase64String(encQuote));
Console.WriteLine("\nDecrypted Quote:\n");
Console.WriteLine(DecryptBytes(aesCSP, encQuote));
}
public static byte[] EncryptString(SymmetricAlgorithm symAlg, string inString)
{
byte[] inBlock = UnicodeEncoding.Unicode.GetBytes(inString);
ICryptoTransform xfrm = symAlg.CreateEncryptor();
byte[] outBlock = xfrm.TransformFinalBlock(inBlock, 0, inBlock.Length);
return outBlock;
}
public static string DecryptBytes(SymmetricAlgorithm symAlg, byte[] inBytes)
{
ICryptoTransform xfrm = symAlg.CreateDecryptor();
byte[] outBlock = xfrm.TransformFinalBlock(inBytes, 0, inBytes.Length);
return UnicodeEncoding.Unicode.GetString(outBlock);
}
}
Imports System.Security.Cryptography
Imports System.Text
Class EncryptorExample
Private Shared quote As String = _
"Things may come to those who wait, but only the " + _
"things left by those who hustle. -- Abraham Lincoln"
Public Shared Sub Main()
Dim aesCSP As New AesCryptoServiceProvider()
aesCSP.GenerateKey()
aesCSP.GenerateIV()
Dim encQuote() As Byte = EncryptString(aesCSP, quote)
Console.WriteLine("Encrypted Quote:" + Environment.NewLine)
Console.WriteLine(Convert.ToBase64String(encQuote))
Console.WriteLine(Environment.NewLine + "Decrypted Quote:" + Environment.NewLine)
Console.WriteLine(DecryptBytes(aesCSP, encQuote))
End Sub
Public Shared Function EncryptString(symAlg As SymmetricAlgorithm, inString As String) As Byte()
Dim inBlock() As Byte = UnicodeEncoding.Unicode.GetBytes(inString)
Dim xfrm As ICryptoTransform = symAlg.CreateEncryptor()
Dim outBlock() As Byte = xfrm.TransformFinalBlock(inBlock, 0, inBlock.Length)
Return outBlock
End Function
Public Shared Function DecryptBytes(symAlg As SymmetricAlgorithm, inBytes() As Byte) As String
Dim xfrm As ICryptoTransform = symAlg.CreateDecryptor()
Dim outBlock() As Byte = xfrm.TransformFinalBlock(inBytes, 0, inBytes.Length)
return UnicodeEncoding.Unicode.GetString(outBlock)
End Function
End Class
Poznámky
Pokud je null
aktuální Key vlastnost , GenerateKey je volána metoda pro vytvoření nového náhodného Keyobjektu . Pokud je null
aktuální IV vlastnost , GenerateIV je volána metoda pro vytvoření nového náhodného IVobjektu .
K dešifrování výsledku CreateDecryptor této metody použijte přetížení se stejným podpisem.
Viz také
Platí pro
CreateEncryptor(Byte[], Byte[])
- Zdroj:
- SymmetricAlgorithm.cs
- Zdroj:
- SymmetricAlgorithm.cs
- Zdroj:
- SymmetricAlgorithm.cs
public:
abstract System::Security::Cryptography::ICryptoTransform ^ CreateEncryptor(cli::array <System::Byte> ^ rgbKey, cli::array <System::Byte> ^ rgbIV);
public abstract System.Security.Cryptography.ICryptoTransform CreateEncryptor (byte[] rgbKey, byte[]? rgbIV);
public abstract System.Security.Cryptography.ICryptoTransform CreateEncryptor (byte[] rgbKey, byte[] rgbIV);
abstract member CreateEncryptor : byte[] * byte[] -> System.Security.Cryptography.ICryptoTransform
Public MustOverride Function CreateEncryptor (rgbKey As Byte(), rgbIV As Byte()) As ICryptoTransform
Parametry
- rgbKey
- Byte[]
Tajný klíč, který se má použít pro symetrický algoritmus.
- rgbIV
- Byte[]
Inicializační vektor, který se má použít pro symetrický algoritmus.
Návraty
Objekt symetrického šifrovače.
Poznámky
K dešifrování výsledku CreateDecryptor této metody použijte přetížení se stejnými parametry.