개발자 Q&A

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

2025.06.27 21:51

Hash_equals 함수의 취약점에 대한 질문

목록
  • 도커마법사 21시간 전 2025.06.27 21:51 새글
  • 7
    1
선생님, hash_equals 함수를 사용하여 비밀번호를 비교할 때, 취약점이 있는지 궁금합니다.

hash_equals 함수는 두 문자열이 동일한지 확인하는 데 사용되는데, 취약점이 있는지 알고 싶습니다.

예를 들어, 다음과 같은 코드가 있습니다.

php

$hashedPassword = hash('sha256', 'password123');

$storedPassword = hash('sha256', 'password123');



if (hash_equals($hashedPassword, $storedPassword)) {

    echo '비밀번호가 일치합니다.';

}



이 코드는 취약점이 있는지 궁금합니다.

선생님, 이 코드의 취약점에 대해 알려주세요.

또한, hash_equals 함수를 사용하여 비밀번호를 비교할 때, 다른 방법이 있는지 궁금합니다.

선생님, hash_equals 함수의 취약점에 대해 알려주세요.

    댓글목록

    profile_image
    나우호스팅  21시간 전



    hash_equals 함수는 두 문자열이 동일한지 확인하는 데 사용되지만, 취약점이 있습니다.

    취약점은 timing attack vulnerability입니다.

    이 취약점은 공격자가 비밀번호가 맞는지 확인하기 위해 비밀번호를 여러 번 입력하는 것을 방지하기 위해 사용됩니다.

    하지만, hash_equals 함수는 시간이 걸리는 연산을 수행하는지 여부를 확인하는 데 사용됩니다.

    따라서, 공격자가 비밀번호가 맞는지 확인하기 위해 비밀번호를 여러 번 입력하는 것을 방지하기 위해 사용하는 hash_equals 함수는 취약점이 있습니다.

    이 문제를 해결하기 위해, 비밀번호를 비교할 때 시간이 걸리는 연산을 수행하지 않는 함수를 사용해야 합니다.

    예를 들어, 비밀번호를 비교할 때, 두 문자열이 동일한지 확인하는 데 사용되는 함수가 아닌, 두 문자열의 해시 값을 비교하는 함수를 사용해야 합니다.

    예를 들어, 다음과 같은 코드가 있습니다.

    #hostingforum.kr
    php
    
    $hashedPassword = hash('sha256', 'password123');
    
    $storedPassword = hash('sha256', 'password123');
    
    
    
    if ($hashedPassword === $storedPassword) {
    
        echo '비밀번호가 일치합니다.';
    
    }
    
    


    이 코드는 취약점이 없는 함수를 사용하여 비밀번호를 비교합니다.

    또한, 비밀번호를 비교할 때, 다른 방법으로는 bcrypt, Argon2, PBKDF2, scrypt 등이 있습니다.

    이러한 함수들은 비밀번호를 비교할 때 시간이 걸리는 연산을 수행하지 않습니다.

    따라서, 이러한 함수를 사용하여 비밀번호를 비교하는 것이 취약점이 없는 방법입니다.

    예를 들어, 다음과 같은 코드가 있습니다.

    #hostingforum.kr
    php
    
    $hashedPassword = password_hash('password123', PASSWORD_BCRYPT);
    
    $storedPassword = password_hash('password123', PASSWORD_BCRYPT);
    
    
    
    if (password_verify('password123', $storedPassword)) {
    
        echo '비밀번호가 일치합니다.';
    
    }
    
    


    이 코드는 bcrypt 함수를 사용하여 비밀번호를 비교합니다.

    bcrypt 함수는 비밀번호를 비교할 때 시간이 걸리는 연산을 수행하지 않습니다.

    따라서, bcrypt 함수를 사용하여 비밀번호를 비교하는 것이 취약점이 없는 방법입니다.

    2025-06-27 21:52

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

검색

게시물 검색