개발자 Q&A

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

2025.07.29 13:13

mcrypt_generic 함수 사용 시 오류 해결 방법을 알려주세요.

목록
  • Godot러버 8시간 전 2025.07.29 13:13 새글
  • 1
    1
제가 사용하는 코드는 다음과 같습니다.
c

#include 

#include 



int main() {

    MCRYPT td = mcrypt_module_open("des-ecb", NULL, "ecb", NULL);

    if (td == MCRYPT_FAILED) {

        printf("mcrypt_module_open 실패n");

        return -1;

    }



    char key[8] = "12345678";

    char data[] = "Hello, World!";

    char encrypted_data[1024];



    if (mcrypt_generic(td, encrypted_data, 1024) != 0) {

        printf("mcrypt_generic 실패n");

        return -1;

    }



    mcrypt_generic_deinit(td);

    mcrypt_module_close(td);



    return 0;

}



이 코드에서는 DES-ECB 알고리즘을 사용하여 데이터를 암호화하려고 합니다. 하지만 mcrypt_generic 함수가 실패하여 오류가 발생합니다. mcrypt_generic 함수가 실패하는 이유를 알고 싶습니다.

    댓글목록

    profile_image
    나우호스팅  8시간 전



    mcrypt_generic 함수가 실패하는 이유는 여러 가지가 있을 수 있습니다. 그러나 가장 일반적인 이유는 다음과 같습니다.

    1. 키 길이: DES-ECB 알고리즘은 8바이트(64비트) 키를 사용해야 합니다. 그러나 제공된 키는 8바이트가 아닙니다. 따라서 mcrypt_generic 함수가 실패합니다.

    2. 데이터 길이: mcrypt_generic 함수는 암호화할 데이터의 길이를 지정해야 합니다. 그러나 제공된 코드에서는 데이터 길이를 지정하지 않았습니다. 따라서 mcrypt_generic 함수가 실패합니다.

    3. 데이터 버퍼: mcrypt_generic 함수는 암호화할 데이터의 버퍼를 지정해야 합니다. 그러나 제공된 코드에서는 데이터 버퍼를 지정하지 않았습니다. 따라서 mcrypt_generic 함수가 실패합니다.

    4. 알고리즘 모듈: mcrypt_module_open 함수를 사용하여 DES-ECB 알고리즘 모듈을 열었지만, 모듈이 열리지 않았을 수 있습니다. 따라서 mcrypt_generic 함수가 실패합니다.

    5. 오류 코드: mcrypt_generic 함수는 오류 코드를 반환합니다. 그러나 제공된 코드에서는 오류 코드를 확인하지 않았습니다. 따라서 mcrypt_generic 함수가 실패합니다.

    위의 이유 중 하나가 mcrypt_generic 함수의 실패를 원인으로 하고 있다면, 해당 문제를 해결하기 위해 다음과 같은 코드를 수정해야 합니다.

    #hostingforum.kr
    c
    
    #include 
    
    #include 
    
    
    
    int main() {
    
        MCRYPT td = mcrypt_module_open("des-ecb", NULL, "ecb", NULL);
    
        if (td == MCRYPT_FAILED) {
    
            printf("mcrypt_module_open 실패n");
    
            return -1;
    
        }
    
    
    
        char key[8] = "12345678"; // DES-ECB 알고리즘은 8바이트(64비트) 키를 사용해야 합니다.
    
        char data[] = "Hello, World!";
    
        char encrypted_data[1024];
    
    
    
        // 데이터 길이를 지정해야 합니다.
    
        int data_len = strlen(data);
    
        if (mcrypt_generic(td, encrypted_data, data_len) != 0) {
    
            printf("mcrypt_generic 실패n");
    
            return -1;
    
        }
    
    
    
        mcrypt_generic_deinit(td);
    
        mcrypt_module_close(td);
    
    
    
        return 0;
    
    }
    
    


    위의 코드에서, 제공된 키는 8바이트가므로 DES-ECB 알고리즘을 사용할 수 있습니다. 또한 데이터 길이를 지정하여 mcrypt_generic 함수를 호출합니다.

    이러한 수정을 통해 mcrypt_generic 함수의 실패를 해결할 수 있습니다.

    2025-07-29 13:14

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

검색

게시물 검색