개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.14 11:56

mcrypt_decrypt 함수 사용 중 오류 발생

목록
  • 코드마스터 오래 전 2025.06.14 11:56 인기
  • 144
    1
안녕하세요 선생님. 저는 mcrypt_decrypt 함수를 사용하여 암호화된 데이터를 복호화하려고 합니다. 하지만 오류가 발생하여 복호화가 되지 않습니다.

mcrypt_decrypt 함수의 사용법을 다시 확인해 본 결과, key와 iv의 길이가 맞지 않아 오류가 발생하는 것 같습니다.

mcrypt_decrypt 함수의 key와 iv의 길이는 어떻게 설정해야 하는지 알려주세요.

아래는 제가 사용하는 코드입니다.

php

$key = substr(md5("암호화된 키"), 0, 16);

$iv = substr(md5("초기화 벡터"), 0, 16);

$decrypted = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $encrypted, MCRYPT_MODE_ECB, $iv);



key와 iv의 길이가 맞는지 확인해 주세요.

    댓글목록

    profile_image
    나우호스팅  오래 전



    mcrypt_decrypt 함수의 key와 iv의 길이는 다음과 같이 설정되어야 합니다.

    - key의 길이는 16, 24, 또는 32 byte여야 합니다. (MCRYPT_RIJNDAEL_128은 128비트 블록 크기를 사용하므로, 16byte로 설정해야 합니다.)
    - iv의 길이는 16 byte여야 합니다.

    위 코드에서 key의 길이는 16 byte로 설정되어 있지만, iv의 길이는 16 byte로 설정되어 있지 않습니다. iv의 길이는 16 byte로 설정해야 합니다.

    또한, mcrypt_decrypt 함수의 마지막 인자는 iv를 받을 수 있지만, iv를 사용하지 않는 경우 NULL을 전달해야 합니다. 위 코드에서 iv를 사용하고 있으므로, NULL 대신 iv를 전달해야 합니다.

    수정된 코드는 다음과 같습니다.

    php
    
    $key = substr(md5("암호화된 키"), 0, 16);
    
    $iv = substr(md5("초기화 벡터"), 0, 16);
    
    $decrypted = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $encrypted, MCRYPT_MODE_ECB);
    
    


    또한, mcrypt 함수는 PHP 7.1에서 deprecated되었으며, PHP 7.2부터는 사용할 수 없습니다. 대신, OpenSSL 함수를 사용하는 것을 권장합니다.

    2025-06-14 11:57

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,646건 / 19 페이지

검색

게시물 검색