ホームページ  >  記事  >  データベース  >  MySQL で AES_DECRYPT() が空の結果を返すのはなぜですか?

MySQL で AES_DECRYPT() が空の結果を返すのはなぜですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-11 09:21:03590ブラウズ

Why Does AES_DECRYPT() Return an Empty Result in MySQL?

MySQL での AES_DECRYPT エラーのトラブルシューティング

AES_ENCRYPT() で以前に暗号化されたデータを復号化しようとすると、AES_DECRYPT()空の結果を返します。暗号化されたデータにアクセスできないため、これはイライラする可能性があります。

MySQL ドキュメントによると、AES_DECRYPT() は、暗号化された文字列を復号化した後に元の文字列を返すことが期待されています。ただし、場合によっては、代わりにバイナリ文字列が返されることがあります。

この問題を解決するには、次のことを試してください:

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

このクエリは、CAST() 関数を使用して、復号化された文字列を変換します。バイナリ文字列を CHAR 文字列に変換すると、正しく表示されます。後続のクエリまたはアプリケーションで「first_name」を使用する代わりに、「first_name_decrypt」を使用して復号化されたデータにアクセスします。

以上がMySQL で AES_DECRYPT() が空の結果を返すのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。