개발자 Q&A

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

2025.04.13 15:31

Sodium 라이브러리에서 password hashing 함수 사용에 대한 질문

목록
  • MariaDB장인 2일 전 2025.04.13 15:31
  • 34
    1
저는 Sodium 라이브러리에서 password hashing 함수인 sodium_crypto_pwhash_scryptsalsa208sha256_str_verify를 사용하고 있습니다.
하지만 이 함수를 사용할 때, salt 값이 무엇인지 이해가 가지 않습니다.
salt 값은 어떤 역할을 하는지 알려주세요? 또한, salt 값을 생성하는 방법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  2일 전



    salt 값은 암호화된 비밀번호에 임의로 생성된 문자열을 의미합니다. 이 salt 값은 비밀번호를 암호화할 때 사용되며, 동일한 비밀번호를 암호화할 때마다 다른 salt 값을 생성하여 암호화된 비밀번호가 동일한 것을 방지합니다.

    salt 값을 생성하는 방법은 다음과 같습니다.

    1. 랜덤 문자열을 생성합니다. 이 문자열의 길이는 16바이트 이상이어야 합니다.
    2. 생성된 랜덤 문자열을 salt 값으로 사용합니다.

    Sodium 라이브러리에서 salt 값을 생성하는 함수는 없습니다. 하지만, 다음의 방법을 사용하여 salt 값을 생성할 수 있습니다.

    #hostingforum.kr
    python
    
    import os
    
    
    
    salt = os.urandom(16)
    
    


    위의 코드는 16바이트의 랜덤 문자열을 생성하여 salt 값으로 사용합니다.

    이 salt 값을 비밀번호를 암호화할 때 사용하여, 암호화된 비밀번호를 저장합니다. 이후 비밀번호를 검증할 때, 동일한 salt 값을 사용하여 암호화된 비밀번호를 검증합니다.

    #hostingforum.kr
    python
    
    import sodium
    
    
    
    password = "비밀번호"
    
    salt = os.urandom(16)
    
    
    
    hashed_password = sodium.crypto_pwhash_scryptsalsa208sha256_str_verify(password, salt)
    
    
    
    print(hashed_password)
    
    


    위의 코드는 비밀번호를 암호화하고, 암호화된 비밀번호를 출력합니다.

    #hostingforum.kr
    python
    
    import sodium
    
    
    
    password = "비밀번호"
    
    salt = os.urandom(16)
    
    hashed_password = sodium.crypto_pwhash_scryptsalsa208sha256_str_verify(password, salt)
    
    
    
    new_password = "비밀번호"
    
    new_hashed_password = sodium.crypto_pwhash_scryptsalsa208sha256_str_verify(new_password, salt)
    
    
    
    print(hashed_password == new_hashed_password)
    
    


    위의 코드는 동일한 비밀번호를 암호화하고, 암호화된 비밀번호를 비교합니다.

    결과는 False가 출력됩니다. 이는 salt 값이 동일하더라도, 동일한 비밀번호를 암호화할 때마다 다른 salt 값을 생성하기 때문입니다.

    2025-04-13 15:32

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

검색

게시물 검색