
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