>백엔드 개발 >PHP 튜토리얼 >PHP 암호화를 Mcrypt에서 OpenSSL로 안전하게 마이그레이션하려면 어떻게 해야 합니까?

PHP 암호화를 Mcrypt에서 OpenSSL로 안전하게 마이그레이션하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-03 16:30:14296검색

How Can I Safely Migrate My PHP Encryption from Mcrypt to OpenSSL?

암호화 문제 방지: Mcrypt에서 OpenSSL로 전환

기존 PHP 모듈인 Mcrypt는 PHP 7.2에서 지원을 중단합니다. 권장되는 대체 제품인 OpenSSL은 구현 방식이 약간 다릅니다. 이 문서에서는 중요한 암호화 속성을 유지하면서 Mcrypt에서 OpenSSL로 코드를 효과적으로 마이그레이션하는 방법을 살펴봅니다.

Mcrypt 코드를 OpenSSL로 변환

특히 다음과 같은 Mcrypt 코드를 고려해 보겠습니다. AES 256 CBC 암호화를 활용합니다:

function encrypt($masterPassword, $data) {
    // ... (Omitted for brevity)
    return base64_encode($iv . $encrypted);
}

function decrypt($masterPassword, $base64) {
    // ... (Omitted for brevity)
    return trim($decrypted);
}

Rijndael-256(Mcrypt에서 사용)은 AES-256(OpenSSL에서 사용)과 동일하지 않다는 점에 유의해야 합니다. OpenSSL에는 Rijndael-256 지원이 부족합니다.

재암호화 필요

따라서 직접 변환이 불가능합니다. 대신, 모든 암호화된 데이터는 OpenSSL에서 AES-256을 사용하여 다시 암호화해야 합니다.

추가 문제 해결

또한 원본 코드에는 몇 가지 중요한 암호화 문제가 있습니다.

  • 인증 부재(다음을 사용하여 쉽게 추가) HMAC)
  • 부적절한 패딩(PKCS#5 패딩 권장)
  • 바이트 안전이 아닌 작업(예: mb_substr())

OpenSSL은 패딩을 단순화합니다. 그러나 defuse/php-encryption과 같은 전용 암호화 라이브러리를 사용하면 보안과 편의성을 높일 수 있습니다.

결론

Mcrypt에서 OpenSSL로 전환하려면 이러한 암호화의 미묘함을 신중하게 고려해야 합니다. 데이터를 다시 암호화하고 추가 취약점을 해결함으로써 개발자는 Mcrypt 지원이 없어도 애플리케이션을 효과적으로 보호할 수 있습니다. OpenSSL 및 defuse/php-encryption은 안정적인 암호화를 위한 강력한 대안을 제공합니다.

위 내용은 PHP 암호화를 Mcrypt에서 OpenSSL로 안전하게 마이그레이션하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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