개발자 Q&A

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

2025.06.11 16:01

sodium_crypto_aead_aegis128l_keygen 함수 이해 도움 부탁드립니다.

목록
  • 프론트마법사 7일 전 2025.06.11 16:01
  • 5
    1
제가 공부하는 중인 sodium 라이브러리의 crypto_aead_aegis128l_keygen 함수에 대해 궁금한 점이 있습니다.
이 함수는 AEGIS128L 알고리즘을 사용하여 키를 생성하는 함수로, 매개변수에 대한 이해가 부족합니다.

1. 이 함수에서 "nonce" 매개변수는 무엇을 의미하며, nonce를 생성하는 방법은 무엇인가요?
2. "key" 매개변수는 어떻게 생성되었으며, 이 매개변수는 반드시 32바이트인지 궁금합니다.
3. 이 함수에서 "ad" 매개변수는 무엇을 의미하며, 이 매개변수는 반드시 16바이트인지 궁금합니다.
4. 이 함수를 호출할 때, nonce와 key는 어떻게 전달해야 하는지 알려주세요.

위의 질문 사항 중, 제가 이해하고자 하는 부분에 대해 도움이 될만한 정보를 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  7일 전



    1. nonce 매개변수는 AEGIS128L 알고리즘에서 사용되는 임의의 비공개 값을 의미합니다.
    nonce를 생성하는 방법은 다음과 같습니다.
    - 임의의 12바이트의 난수 값을 생성합니다.
    - 이 난수 값을 12바이트로 변환합니다.

    2. key 매개변수는 AEGIS128L 알고리즘에서 사용되는 암호화 키를 의미합니다.
    이 매개변수는 반드시 32바이트여야 합니다.
    - key 매개변수는 crypto_aead_aegis128l_keygen 함수에 의해 생성됩니다.
    - crypto_aead_aegis128l_keygen 함수는 nonce 매개변수를 사용하여 key 매개변수를 생성합니다.

    3. ad 매개변수는 Associated Data를 의미합니다.
    이 매개변수는 16바이트여야 합니다.
    - ad 매개변수는 암호화할 데이터와 관련된 정보를 포함합니다.
    - ad 매개변수는 AEGIS128L 알고리즘에서 사용됩니다.

    4. 이 함수를 호출할 때, nonce와 key는 다음과 같이 전달해야 합니다.
    - nonce 매개변수는 12바이트의 난수 값을 12바이트로 변환한 값을 전달해야 합니다.
    - key 매개변수는 crypto_aead_aegis128l_keygen 함수에 의해 생성된 32바이트의 암호화 키를 전달해야 합니다.
    - ad 매개변수는 16바이트의 Associated Data를 전달해야 합니다.

    예제 코드는 다음과 같습니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        unsigned char nonce[12];
    
        unsigned char key[32];
    
        unsigned char ad[16];
    
    
    
        // nonce 생성
    
        randombytes(nonce, 12);
    
    
    
        // key 생성
    
        crypto_aead_aegis128l_keygen(nonce, key);
    
    
    
        // ad 생성
    
        randombytes(ad, 16);
    
    
    
        // AEGIS128L 알고리즘 호출
    
        unsigned char ciphertext[32];
    
        unsigned long long ciphertext_len = 32;
    
        unsigned long long plaintext_len = 32;
    
        unsigned long long tag_len = 16;
    
        if (crypto_aead_aegis128l_encrypt(ciphertext, &ciphertext_len, plaintext, &plaintext_len, ad, 16, nonce, key) != 0) {
    
            printf("Error: crypto_aead_aegis128l_encrypt failedn");
    
            return 1;
    
        }
    
    
    
        return 0;
    
    }
    
    

    이 예제 코드는 AEGIS128L 알고리즘을 사용하여 데이터를 암호화합니다. nonce, key, ad 매개변수는 위 설명과 같이 생성됩니다.

    2025-06-11 16:02

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

검색

게시물 검색