Heim > Datenbank > MySQL-Tutorial > Hauptteil

Warum gibt AES_DECRYPT verschlüsselte Daten in MySQL zurück?

Barbara Streisand
Freigeben: 2024-11-10 13:46:03
Original
647 Leute haben es durchsucht

Why is AES_DECRYPT Returning Encrypted Data in MySQL?

Verschlüsselte Daten können nach AES_ENCRYPT in MySQL nicht entschlüsselt werden

Problembeschreibung:

Nach der Verschlüsselung Daten mithilfe von AES_ENCRYPT in einer MySQL-Tabelle, führt ein Versuch, die Daten mithilfe von AES_DECRYPT zu entschlüsseln, dazu, dass der entschlüsselte Wert nicht angezeigt werden kann.

Lösung:

Gemäß MySQL Manuell, AES_DECRYPT soll nach der Entschlüsselung die ursprüngliche Zeichenfolge zurückgeben. Der Benutzer stellt jedoch fest, dass der entschlüsselte Wert immer noch als Binärzeichenfolge zurückgegeben wird. Um dieses Problem zu beheben, sollte der Benutzer versuchen, die entschlüsselte Zeichenfolge mithilfe der CAST-Funktion in eine Zeichenfolge umzuwandeln.

Beispielsweise wandelt die folgende Abfrage die entschlüsselte Spalte „Vorname“ in eine Zeichenfolge mit 50 Zeichen um:

SELECT *, 
       CAST(AES_DECRYPT(first_name, 'usa2010') AS CHAR(50)) first_name_decrypt 
FROM   user
Nach dem Login kopieren

Der Benutzer kann dann die Spalte „first_name_decrypt“ verwenden, um die entschlüsselten Daten in einem lesbaren Format anzuzeigen.

Das obige ist der detaillierte Inhalt vonWarum gibt AES_DECRYPT verschlüsselte Daten in MySQL zurück?. 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