개발자 Q&A

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

2025.04.14 17:16

Sodium Crypto AEAD Aegis256 Keygen에 대한 도움을 요청합니다.

목록
  • 레디스매니아 2일 전 2025.04.14 17:16
  • 17
    1
저는 현재 Sodium Crypto 라이브러리에서 AEAD(Authenticated Encryption with Associated Data) 알고리즘인 Aegis256에 대한 키 생성을 처리하는 함수인 sodium_crypto_aead_aegis256_keygen에 관한 궁금증을 가지고 있습니다.

이 함수는 256비트의 키를 생성하는 데 사용되는데, 사용자 입력으로부터 키를 생성하는 방법을 알고 싶습니다.

키 생성에 사용되는 seed값이 무엇이며, seed값을 생성하는 방법을 알려주세요. 또한, seed값의 길이가 지정된 경우에는 그 기준이 무엇인지 알려주실 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    sodium_crypto_aead_aegis256_keygen 함수는 256비트의 키를 생성하는 데 사용되며, 사용자 입력으로부터 키를 생성하는 방법은 다음과 같습니다.

    1. seed값은 키 생성에 사용되는 랜덤한 값입니다.
    2. seed값은 32바이트(256비트)의 길이를 가집니다.
    3. seed값을 생성하는 방법은 sodium_crypto_secretbox_keygen 함수를 사용하는 것입니다.
    4. sodium_crypto_secretbox_keygen 함수는 32바이트(256비트)의 키를 생성하는 데 사용되며, 사용자 입력으로부터 키를 생성하는 방법은 다음과 같습니다.
    * 사용자 입력으로부터 32바이트의 랜덤한 값을 생성합니다.
    * 생성된 랜덤한 값을 seed값으로 사용합니다.

    seed값의 길이가 지정된 경우, 기준은 32바이트(256비트)입니다. seed값의 길이가 32바이트 미만인 경우, 추가적인 랜덤한 값을 생성하여 seed값을 32바이트로 확장해야 합니다.

    예를 들어, 사용자 입력으로부터 16바이트의 랜덤한 값을 생성한 경우, 추가적인 16바이트의 랜덤한 값을 생성하여 seed값을 32바이트로 확장해야 합니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    unsigned char seed[32];
    
    
    
    // 사용자 입력으로부터 16바이트의 랜덤한 값을 생성합니다.
    
    sodium_random(seed, 16);
    
    
    
    // 추가적인 16바이트의 랜덤한 값을 생성합니다.
    
    sodium_random(seed + 16, 16);
    
    
    
    // seed값을 32바이트로 확장합니다.
    
    sodium_memzero(seed + 32, 16);
    
    

    2025-04-14 17:17

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

검색

게시물 검색