Heim >Backend-Entwicklung >C++ >Wie verschlüsseln und entschlüsseln Sie Strings in C# mit Rijndaelmanaged und der Kryptographie -API?

Wie verschlüsseln und entschlüsseln Sie Strings in C# mit Rijndaelmanaged und der Kryptographie -API?

Susan Sarandon
Susan SarandonOriginal
2025-02-02 16:56:10183Durchsuche

How to Encrypt and Decrypt Strings in C# Using RijndaelManaged and the Cryptography API?

C# String -Verschlüsselung und Entschlüsselung

In C#sind String -Verschlüsselung und Entschlüsselung die wichtigsten Links des Datenschutzes. Lassen Sie uns zwei häufig verwendete Methoden diskutieren:

<.> 1. verwenden Sie die rijndaelmanaged -Klasse

Die rijndaelmanaged -Klasse bietet eine starke Implementierung der populären AES -Algorithmen (Advanced Encryption Standards). Das Folgende ist ein Beispiel für Verschlüsselung und geheime Zeichenfolge:

<.> 2. verwenden Sie die Kryptographie -API

<code class="language-csharp">using System.Security.Cryptography;
using System.Text;

public static class Crypto
{
    // 虽然应用程序特定的盐不是基于密码的加密的最佳实践,
    // 但只要它确实不常见,它可能足够安全。修改此答案还需要做很多工作。
    private static byte[] _salt = { ... };

    public static string Encrypt(string plainText, string sharedSecret)
    {
        // 从共享密钥和盐生成密钥
        Rfc2898DeriveBytes key = new Rfc2898DeriveBytes(sharedSecret, _salt);

        // 创建 RijndaelManaged 对象
        RijndaelManaged aesAlg = new RijndaelManaged();
        aesAlg.Key = key.GetBytes(aesAlg.KeySize / 8);

        // 加密数据
        ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);
        byte[] cipherText = null;

        using (MemoryStream msEncrypt = new MemoryStream())
        {
            // 添加 IV
            msEncrypt.Write(BitConverter.GetBytes(aesAlg.IV.Length), 0, sizeof(int));
            msEncrypt.Write(aesAlg.IV, 0, aesAlg.IV.Length);

            using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
            {
                using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
                {
                    // 将数据写入流
                    swEncrypt.Write(plainText);
                }
            }

            cipherText = msEncrypt.ToArray();
        }

        // 将加密的字节作为 base64 字符串返回
        return Convert.ToBase64String(cipherText);
    }

    public static string Decrypt(string cipherText, string sharedSecret)
    {
        // 从共享密钥和盐生成密钥
        Rfc2898DeriveBytes key = new Rfc2898DeriveBytes(sharedSecret, _salt);

        // 创建 RijndaelManaged 对象
        RijndaelManaged aesAlg = new RijndaelManaged();
        aesAlg.Key = key.GetBytes(aesAlg.KeySize / 8);

        // 解密数据
        ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);
        byte[] plainText = null;

        using (MemoryStream msDecrypt = new MemoryStream(Convert.FromBase64String(cipherText)))
        {
            // 从加密流中获取初始化向量
            aesAlg.IV = ReadByteArray(msDecrypt);

            using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
            {
                using (StreamReader srDecrypt = new StreamReader(csDecrypt))
                {
                    // 从解密流中读取解密的字节
                    plainText = Encoding.UTF8.GetBytes(srDecrypt.ReadToEnd());
                }
            }
        }

        // 将解密的文本作为字符串返回
        return Encoding.UTF8.GetString(plainText);
    }

    // 读取流中字节数组的辅助方法
    private static byte[] ReadByteArray(Stream s)
    {
        byte[] rawLength = new byte[sizeof(int)];
        if (s.Read(rawLength, 0, rawLength.Length) != rawLength.Length)
        {
            throw new InvalidOperationException("流不包含正确格式的字节数组");
        }

        byte[] buffer = new byte[BitConverter.ToInt32(rawLength, 0)];
        if (s.Read(buffer, 0, buffer.Length) != buffer.Length)
        {
            throw new InvalidOperationException("未正确读取字节数组");
        }

        return buffer;
    }
}</code>

Kryptographie -API in C# bietet eine Vielzahl von Klassen für Sicherheitsverschlüsselungsvorgänge. Das Folgende ist ein Beispiel für die Verwendung dieser API -Verschlüsselung und der geheimen Zeichenfolge:

Beide Methoden bieten einen leistungsstarken Verschlüsselungs- und Entschlüsselungsmechanismus zum Schutz der sensiblen Daten in C#. Die Rijndaelmanaged -Klasse ist ein ausgereifter und weit verbreiteter Algorithmus, und die Kryptographie -API bietet zusätzliche Funktionen und Flexibilität. Bitte beachten Sie, dass die Definition von

im Code weggelassen wird und ein sicherer Salzwert in der tatsächlichen Verwendung definiert werden muss. Darüber hinaus wird für die Produktionsumgebung empfohlen, leistungsfähigeres Schlüsselmanagement und sicherere, wichtige abgeleitete Methoden zu verwenden.

Das obige ist der detaillierte Inhalt vonWie verschlüsseln und entschlüsseln Sie Strings in C# mit Rijndaelmanaged und der Kryptographie -API?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn