개발자 Q&A

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

2025.08.06 15:21

Sodium 라이브러리에서 password hashing에 사용되는 scrypt 알고리즘의 구체적인 구현에 대해 질문합니다.

목록
  • Firebase러버 6시간 전 2025.08.06 15:21 새글
  • 1
    1
제가 이해한 바에 따르면 sodium_crypto_pwhash_scryptsalsa208sha256_str 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.
이 알고리즘은 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.
하지만, scrypt 알고리즘의 구체적인 구현에 대해 궁금합니다.
scrypt 알고리즘은 salt, cost factor, 그리고 블록 크기를 사용하여 password를 hashing합니다.
다만, sodium_crypto_pwhash_scryptsalsa208sha256_str 함수의 cost factor는 4096로 고정되어 있나요?
또한, salt는 어떻게 생성되고 사용되는가요?

위의 내용에 대해 구체적인 답변을 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  6시간 전



    sodium_crypto_pwhash_scryptsalsa208sha256_str 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    scrypt 알고리즘은 salt, cost factor, 그리고 블록 크기를 사용하여 password를 hashing합니다.

    cost factor는 고정되어 있지 않습니다. 이 함수의 cost factor는 4096이지만, 사용자가 직접 cost factor를 설정할 수 있습니다.

    salt는 사용자가 직접 생성하거나, 함수에 salt를 전달하여 생성할 수 있습니다.

    sodium_crypto_pwhash_scryptsalsa208sha256_str 함수의 기본적인 사용 방법은 다음과 같습니다.

    #hostingforum.kr
    c
    
    char password[] = "password";
    
    unsigned char salt[16];
    
    unsigned char hash[64];
    
    
    
    sodium_init();
    
    sodium_crypto_pwhash_scryptsalsa208sha256_str(hash, password, strlen(password), salt, 4096, 8, 1);
    
    


    위의 코드는 password를 salt와 함께 hashing하고, 결과를 hash에 저장합니다.

    cost factor는 4096로 고정되어 있지 않습니다. 사용자가 직접 cost factor를 설정할 수 있습니다.

    #hostingforum.kr
    c
    
    sodium_crypto_pwhash_scryptsalsa208sha256_str(hash, password, strlen(password), salt, 65536, 8, 1);
    
    


    위의 코드는 cost factor를 65536으로 설정합니다.

    salt는 사용자가 직접 생성하거나, 함수에 salt를 전달하여 생성할 수 있습니다.

    #hostingforum.kr
    c
    
    unsigned char salt[16];
    
    sodium_randombytes_buf(salt, 16);
    
    sodium_crypto_pwhash_scryptsalsa208sha256_str(hash, password, strlen(password), salt, 4096, 8, 1);
    
    


    위의 코드는 salt를 16바이트의 난수값으로 생성합니다.

    sodium_crypto_pwhash_scryptsalsa208sha256_str 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    scrypt 알고리즘은 salt, cost factor, 그리고 블록 크기를 사용하여 password를 hashing합니다.

    cost factor는 고정되어 있지 않으며, 사용자가 직접 설정할 수 있습니다.

    salt는 사용자가 직접 생성하거나, 함수에 salt를 전달하여 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수와 sha256 해시 함수를 함께 사용합니다.

    이 함수는 password를 hashing하고, 결과를 hash에 저장합니다.

    이 함수는 sodium 라이브러리의 일부로 제공됩니다.

    이 함수는 password를 hashing하는 데 사용됩니다.

    이 함수는 scrypt 알고리즘을 사용하여 password를 hashing합니다.

    이 함수는 cost factor를 설정할 수 있습니다.

    이 함수는 salt를 생성할 수 있습니다.

    이 함수는 salsa20/8 블록 암호화 함수

    2025-08-06 15:22

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

검색

게시물 검색