Heim > Backend-Entwicklung > C++ > Warum erhalte ich in meiner C#-Rijndael-Verschlüsselung die Ausnahme „Padding ist ungültig und kann nicht entfernt werden'?

Warum erhalte ich in meiner C#-Rijndael-Verschlüsselung die Ausnahme „Padding ist ungültig und kann nicht entfernt werden'?

Linda Hamilton
Freigeben: 2025-01-08 22:18:57
Original
744 Leute haben es durchsucht

Why Am I Getting a

Ausnahme „Padding ist ungültig und kann nicht entfernt werden“ im C#-Rijndael-Verschlüsselungs- und Entschlüsselungsprogramm

In der Kryptografie tritt die Ausnahme „Padding ist ungültig und kann nicht entfernt werden“ auf, wenn versucht wird, mit dem Rijndael-Algorithmus verschlüsselte Daten zu entschlüsseln. Diese Ausnahme weist darauf hin, dass die bei der Verschlüsselung verwendete Auffüllung nicht den Erwartungen des Entschlüsselungsalgorithmus entspricht.

Polsterung in Rijndael verstehen

Rijndael (auch bekannt als AES) arbeitet mit Datenblöcken fester Größe. Wenn die Größe der verschlüsselten Daten nicht durch die Blockgröße teilbar ist, wird der verbleibende Platz durch Auffüllen aufgefüllt. Durch diese Auffüllung wird sichergestellt, dass der Chiffretext ein gültiger, vollständiger Block ist.

Entschlüsselungsprozess

Während der Entschlüsselung versucht der Algorithmus, Auffüllungen aus dem Chiffretext zu entfernen. Wenn die Auffüllung jedoch nicht den Erwartungen entspricht, wird die Ausnahme „Auffüllung ist ungültig und kann nicht entfernt werden“ ausgelöst. Das bedeutet, dass die Verschlüsselungs- und Entschlüsselungsalgorithmen unterschiedliche Füllschemata verwenden.

Lösung: Polsterung explizit angeben

Um dieses Problem zu lösen, muss das Auffüllschema für die Ver- und Entschlüsselung explizit angegeben werden. Dies kann mit dem folgenden Code erfolgen:

<code class="language-csharp">// 加密
symmetricAlgorithm.Padding = PaddingMode.PKCS7;

// 解密
EncryptedXml exml = new EncryptedXml();
exml.Padding = PaddingMode.PKCS7;</code>
Nach dem Login kopieren

PKCS#7-Polsterung

Es wird empfohlen, PKCS#7-Auffüllung zu verwenden, es sei denn, es gibt einen bestimmten Grund, ein anderes Auffüllungsschema zu verwenden. PKCS#7 (auch bekannt als OAEP (Optimal Asymmetric Encryption Padding)) ist ein weithin unterstützter und sicherer Padding-Algorithmus, der die Integrität verschlüsselter Daten gewährleistet.

Weitere Hinweise

  • Überprüfen Sie, ob die für die Verschlüsselung und Entschlüsselung verwendete Schlüsselgröße gleich ist.
  • Stellen Sie sicher, dass Initialisierungsvektoren (IVs) korrekt verarbeitet werden.
  • Verwenden Sie eine Bibliothek oder ein Framework, das die Rijndael-Verschlüsselung mit PKCS#7-Padding unterstützt, um die Implementierung zu vereinfachen.

Das obige ist der detaillierte Inhalt vonWarum erhalte ich in meiner C#-Rijndael-Verschlüsselung die Ausnahme „Padding ist ungültig und kann nicht entfernt werden'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage