개발자 Q&A

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

2025.06.02 18:00

sodium_crypto_pwhash_scryptsalsa208sha256 함수 이해를 도와주세요.

목록
  • 코드주술사 오래 전 2025.06.02 18:00 인기
  • 105
    1
제가 공부중인 암호학에 관련된 함수인 sodium_crypto_pwhash_scryptsalsa208sha256를 사용하여 비밀번호 해시를 만들 때,
어떻게 비밀번호와 소금값(salt)을 입력하여 해시를 만들 수 있는지 궁금합니다.
또한 이 함수의 파라미터 중에서 n, r, p, memlimit를 어떻게 설정해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  오래 전



    sodium_crypto_pwhash_scryptsalsa208sha256 함수는 비밀번호 해시를 생성하기 위해 사용되는 함수입니다. 이 함수의 기본적인 사용 방법은 다음과 같습니다.

    1. 비밀번호와 소금값(salt)을 입력합니다. 소금값은 고유한 값으로, 동일한 비밀번호에 대해 항상 다른 해시 값을 생성하도록 합니다.
    2. n, r, p, memlimit 파라미터를 설정합니다. 이 파라미터는 Scrypt 알고리즘의 속도와 안전성을 결정합니다.
    - n: Scrypt 알고리즘의 반복 횟수를 결정합니다. 일반적으로 2^14 (16,384) 이상의 값을 사용합니다.
    - r: Scrypt 알고리즘의 블록 크기를 결정합니다. 일반적으로 8 이상의 값을 사용합니다.
    - p: Scrypt 알고리즘의 블록 크기를 결정합니다. 일반적으로 1 이상의 값을 사용합니다.
    - memlimit: Scrypt 알고리즘의 메모리 사용량을 결정합니다. 일반적으로 2^22 (4,194,304) 이상의 값을 사용합니다.

    이러한 파라미터를 설정한 후, sodium_crypto_pwhash_scryptsalsa208sha256 함수를 호출하여 비밀번호 해시를 생성할 수 있습니다.

    예를 들어, 다음 코드는 비밀번호 "password"와 소금값 "salt"를 사용하여 해시를 생성합니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        unsigned char password[] = "password";
    
        unsigned char salt[] = "salt";
    
        unsigned char hash[64];
    
        size_t hash_len = 64;
    
    
    
        if (sodium_crypto_pwhash_scryptsalsa208sha256(hash, &hash_len, password, strlen(password), salt, strlen(salt), 2^14, 8, 1, 2^22) == 0) {
    
            printf("Hash: %sn", sodium_bin2hex(hash, hash_len));
    
        } else {
    
            printf("Error: %sn", sodium_strerror(errno));
    
        }
    
    
    
        return 0;
    
    }
    
    


    이 코드는 Scrypt 알고리즘의 기본 설정인 n=2^14, r=8, p=1, memlimit=2^22을 사용합니다. 비밀번호 "password"와 소금값 "salt"를 사용하여 해시를 생성하고, 생성된 해시 값을 출력합니다.

    2025-06-02 18:01

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

검색

게시물 검색