>  기사  >  데이터 베이스  >  내 MySQL AES 암호 해독이 빈 결과를 반환하는 이유는 무엇입니까?

내 MySQL AES 암호 해독이 빈 결과를 반환하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-13 06:07:02500검색

Why Does My MySQL AES Decryption Return Blank Results?

MySQL의 AES 암호 해독 문제 해결

MySQL에서 암호화된 데이터로 작업할 때는 사용 가능한 암호화 및 암호 해독 기능을 이해하는 것이 중요합니다. 이 문서에서는 AES 암호화를 사용하여 암호화된 데이터를 해독하려고 할 때 빈 결과가 나타나는 문제를 다룹니다.

MySQL에서 AES_ENCRYPT 및 AES_DECRYPT 함수는 모두 이진 문자열에서 작동합니다. 의도된 동작은 AES_DECRYPT가 해독된 데이터를 문자열로 반환하는 것입니다. 그러나 특정 시나리오에서는 해독된 데이터가 여전히 이진 형식일 수 있으므로 빈 결과가 표시될 수 있습니다.

이 문제를 해결하기 위해 MySQL 매뉴얼에서는 CAST() 함수를 사용하여 해독된 이진 문자열을 명시적으로 변환할 것을 권장합니다. 문자열로. 구현 방법은 다음과 같습니다.

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

이 쿼리에서 해독된 first_name 열은 최대 길이가 50자인 문자열로 캐스팅됩니다. 이렇게 하면 해독된 데이터가 읽을 수 있는 텍스트 문자열로 표시됩니다.

이 접근 방식을 따르면 테이블에서 암호화된 데이터를 성공적으로 해독하고 볼 수 있습니다. 해독된 데이터의 예상 길이에 따라 필요에 따라 CAST() 함수의 문자 길이를 조정하는 것을 잊지 마세요.

위 내용은 내 MySQL AES 암호 해독이 빈 결과를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.