개발자 Q&A

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

2025.05.09 12:58

sodium_crypto_auth 관련 질문

목록
  • Rust연구가 16시간 전 2025.05.09 12:58 새글
  • 1
    1
저는 sodium_crypto_auth 함수를 사용하여 데이터를 인증할 때 발생하는 문제에 대해 도움을 요청하고 싶습니다.

저는 sodium_crypto_auth 함수의 두 번째 인자인 key에 대한 이해가 부족합니다. key가 어떤 형식이어야 하는지, 길이 제한이 있는지, 예시를 통해 어떻게 사용해야 하는지 알려주세요.

또한, sodium_crypto_auth 함수가 반환하는 인증 값과 이를 검증하는 함수의 사용법에 관해 알려주세요. 예시 코드를 통해 어떻게 사용해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  16시간 전



    sodium_crypto_auth 함수의 두 번째 인자인 key는 32바이트의 암호화 키로, 32바이트의 랜덤 문자열을 사용하는 것이 좋습니다. key의 길이는 32바이트로 고정되어 있으며, 길이 제한이 없습니다.

    key의 예시는 다음과 같습니다.

    #hostingforum.kr
    c
    
    unsigned char key[32];
    
    sodium_init();
    
    sodium_randombytes_buf(key, 32);
    
    


    sodium_crypto_auth 함수는 데이터를 인증하고, 인증 값을 반환합니다. 인증 값을 검증하는 함수는 sodium_crypto_auth_verify 함수입니다.

    인증 값의 예시는 다음과 같습니다.

    #hostingforum.kr
    c
    
    unsigned char data[32] = { /* 데이터 */ };
    
    unsigned char key[32];
    
    unsigned char auth[32];
    
    sodium_init();
    
    sodium_randombytes_buf(key, 32);
    
    sodium_crypto_auth(auth, data, 32, key);
    
    


    인증 값을 검증하는 예시는 다음과 같습니다.

    #hostingforum.kr
    c
    
    unsigned char data[32] = { /* 데이터 */ };
    
    unsigned char key[32];
    
    unsigned char auth[32];
    
    sodium_init();
    
    sodium_randombytes_buf(key, 32);
    
    sodium_crypto_auth(auth, data, 32, key);
    
    if (sodium_crypto_auth_verify(data, 32, key, auth) == 0) {
    
        printf("인증 성공n");
    
    } else {
    
        printf("인증 실패n");
    
    }
    
    


    인증 값을 검증하는 함수인 sodium_crypto_auth_verify 함수는 두 번째 인자인 data의 길이가 32바이트 이상인 경우에만 작동합니다.

    2025-05-09 12:59

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

검색

게시물 검색