개발자 Q&A

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

2025.03.03 00:53

Sodium_crypto_aead_aegis128l_decrypt 함수 사용에 대한 도움을 부탁드립니다.

  • Firebase러버 12일 전 2025.03.03 00:53
  • 13
    1

제가 공부 중인 sodium 라이브러리에서 crypto_aead_aegis128l_decrypt 함수를 사용하여 암호문을 복호화하는 데 어려움을 겪고 있습니다.

해시값을 제공하여 암호문을 복호화하는 방법에 대해 알려주시면 감사하겠습니다.

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

c

#include 



char *복호화(const char *복호화_암호문, const char *복호화_키, const char *복호화_해시) {

    unsigned char 복호화_해시_배열[crypto_aead_aes128gcm_AUTHBYTES];

    memcpy(복호화_해시_배열, 복호화_해시, crypto_aead_aes128gcm_AUTHBYTES);



    unsigned char 복호화_키_배열[crypto_aead_aes128gcm_KEYBYTES];

    memcpy(복호화_키_배열, 복호화_키, crypto_aead_aes128gcm_KEYBYTES);



    unsigned long long 복호화_키_길이 = crypto_aead_aes128gcm_KEYBYTES;



    char *복호화_결과 = malloc(crypto_aead_aes128gcm_ABYTES + strlen(복호화_암호문));

    if (복호화_결과 == NULL) {

        return NULL;

    }



    if (crypto_aead_aes128gcm_decrypt(복호화_결과, 복호화_암호문, NULL, NULL, 0, 복호화_키_배열, 복호화_해시_배열, 복호화_키_길이) != 0) {

        free(복호화_결과);

        return NULL;

    }



    복호화_결과[crypto_aead_aes128gcm_ABYTES] = '�';



    return 복호화_결과;

}



해시값을 제공하여 암호문을 복호화하는 방법에 대해 알려주시면 감사하겠습니다.

위 코드에서 crypto_aead_aes128gcm_decrypt 함수를 사용하여 복호화하는 방법에 대해 알려주세요.

    댓글목록

    profile_image
    나우호스팅  12일 전



    해시값을 제공하여 암호문을 복호화하는 방법은 다음과 같습니다.

    1. `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 암호문을 복호화합니다. 이 함수는 암호문을 복호화하고, 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    2. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다. 이 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다. 이 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.

    `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법을示す 코드는 다음과 같습니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    char *복호화(const char *복호화_암호문, const char *복호화_키, const char *복호화_해시) {
    
        unsigned char 복호화_해시_배열[crypto_aead_aes128gcm_AUTHBYTES];
    
        memcpy(복호화_해시_배열, 복호화_해시, crypto_aead_aes128gcm_AUTHBYTES);
    
    
    
        unsigned char 복호화_키_배열[crypto_aead_aes128gcm_KEYBYTES];
    
        memcpy(복호화_키_배열, 복호화_키, crypto_aead_aes128gcm_KEYBYTES);
    
    
    
        unsigned long long 복호화_키_길이 = crypto_aead_aes128gcm_KEYBYTES;
    
    
    
        char *복호화_결과 = malloc(crypto_aead_aes128gcm_ABYTES + strlen(복호화_암호문));
    
        if (복호화_결과 == NULL) {
    
            return NULL;
    
        }
    
    
    
        if (crypto_aead_aes128gcm_decrypt(복호화_결과, 복호화_암호문, NULL, NULL, 0, 복호화_키_배열, 복호화_해시_배열, 복호화_키_길이) != 0) {
    
            free(복호화_결과);
    
            return NULL;
    
        }
    
    
    
        복호화_결과[crypto_aead_aes128gcm_ABYTES] = '';
    
    
    
        return 복호화_결과;
    
    }
    
    


    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128gcm_decrypt` 함수를 사용하여 복호화하는 방법은 다음과 같습니다.

    1. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.
    2. `crypto_aead_aes128gcm_decrypt` 함수는 복호화된 데이터를 `복호화_결과` 변수에 저장합니다.
    3. `복호화_결과` 변수는 `crypto_aead_aes128gcm_ABYTES` 크기의 버퍼를 할당받은 후, `crypto_aead_aes128gcm_decrypt` 함수를 호출하여 암호문을 복호화합니다.

    위 코드에서 `crypto_aead_aes128g

    2025-03-03 00:54

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

검색

게시물 검색