개발자 Q&A

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

2025.06.06 06:19

sodium_crypto_pwhash_scryptsalsa208sha256_str 함수 사용시 오류 해결 방법을 알려주세요

목록
  • 리버스엔지니어링도령 오래 전 2025.06.06 06:19
  • 84
    1
제가 공부중인 암호학 관련 주제인 나트륨(NaCl) 라이브러리 함수인 sodium_crypto_pwhash_scryptsalsa208sha256_str를 사용하여 비밀번호 해시를 생성하려고 하는데요.

해시 생성 시에 salt 값을 지정할 때, salt 값의 길이가 32바이트가 넘어가는 경우 오류가 발생합니다.

오류가 발생하는 이유를 알려주시고, salt 값의 길이를 제한하는 방법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  오래 전



    sodium_crypto_pwhash_scryptsalsa208sha256_str 함수는 salt 값의 길이를 32바이트로 제한합니다.
    이 함수는 salt 값의 길이가 32바이트를 넘을 경우 오류를 발생시키는 것입니다.
    이러한 오류를 해결하기 위해서는 salt 값의 길이를 32바이트 이하로 제한하거나, 다른 함수를 사용하는 방법이 있습니다.

    salt 값의 길이를 제한하는 방법은 다음과 같습니다.

    1. salt 값의 길이를 32바이트 이하로 제한하여 함수를 호출합니다.
    2. 다른 함수를 사용하여 salt 값을 생성합니다. 예를 들어, sodium_randombytes_buf 함수를 사용하여 32바이트의 난수 값을 생성할 수 있습니다.

    다음은 예제입니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        unsigned char salt[32];
    
        unsigned char hash[64];
    
    
    
        // 32바이트의 난수 값을 생성합니다.
    
        sodium_randombytes_buf(salt, 32);
    
    
    
        // salt 값을 사용하여 비밀번호 해시를 생성합니다.
    
        if (sodium_crypto_pwhash_scryptsalsa208sha256_str(hash, 64, "비밀번호", strlen("비밀번호"), salt, 32, 4096, 8, 1) != 0) {
    
            printf("오류가 발생했습니다.n");
    
            return 1;
    
        }
    
    
    
        // 비밀번호 해시를 출력합니다.
    
        printf("비밀번호 해시: ");
    
        for (int i = 0; i < 64; i++) {
    
            printf("%02x", hash[i]);
    
        }
    
        printf("n");
    
    
    
        return 0;
    
    }
    
    


    이 예제는 32바이트의 난수 값을 생성하여 salt 값을 사용하여 비밀번호 해시를 생성합니다.

    2025-06-06 06:20

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

검색

게시물 검색