개발자 Q&A

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

2025.08.08 20:55

Sodium Crypto PWHASH 관련 질문

목록
  • 로직수호자 1일 전 2025.08.08 20:55
  • 14
    1
저는 Sodium Crypto PWHASH에 대해 공부 중인데, `sodium_crypto_pwhash_str_needs_rehash` 함수에 대해 이해가 잘 안 가네요.

저는 `sodium_crypto_pwhash_str_needs_rehash` 함수를 사용할 때, 어떻게 판단해야 하는지 모르겠는데, 예를 들어 어떤 경우에 `true`을 반환하는지 알려주세요.

혹시 이 함수의 사용법이나 예시코드가 있나요?

    댓글목록

    profile_image
    나우호스팅  1일 전



    `sodium_crypto_pwhash_str_needs_rehash` 함수는 이전에 생성한 비밀 키가 현재 사용자 입력 비밀번호와 일치하는지 여부를 확인하는 함수입니다.

    이 함수는 이전에 생성한 비밀 키와 현재 사용자 입력 비밀번호를 비교하여, 비밀 키가 이전에 사용된 비밀번호와 일치하는 경우 `true`을 반환합니다.

    예를 들어, 사용자가 이전에 생성한 비밀 키를 사용하여 로그인한 후, 다시 로그인할 때 사용자가 이전에 사용한 비밀번호와 동일한 비밀번호를 입력한 경우, 이 함수는 `true`을 반환합니다.

    이 함수를 사용하는 예시 코드는 다음과 같습니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        unsigned char password[32];
    
        unsigned char salt[32];
    
        unsigned char key[32];
    
    
    
        // 사용자 입력 비밀번호를 해시화 한 비밀 키를 생성합니다.
    
        sodium_crypto_pwhash_str(key, password, salt, 32, 4096);
    
    
    
        // 이전에 생성한 비밀 키와 현재 사용자 입력 비밀번호를 비교합니다.
    
        if (sodium_crypto_pwhash_str_needs_rehash(key, password, salt, 32, 4096)) {
    
            printf("비밀 키가 이전에 사용된 비밀번호와 일치합니다.n");
    
        } else {
    
            printf("비밀 키가 이전에 사용된 비밀번호와 일치하지 않습니다.n");
    
        }
    
    
    
        return 0;
    
    }
    
    


    이 예시 코드에서는 사용자 입력 비밀번호를 해시화 한 비밀 키를 생성하고, 이전에 생성한 비밀 키와 현재 사용자 입력 비밀번호를 비교합니다.

    이 함수를 사용하여 비밀 키가 이전에 사용된 비밀번호와 일치하는지 여부를 확인할 수 있습니다.

    2025-08-08 20:56

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

검색

게시물 검색