PHP의 안전한 난수 생성: 종합 개요
암호화에는 예측할 수 없는 난수 생성이 필요한 경우가 많습니다. PHP에서 "mt_rand" 함수는 이러한 요구 사항에 미치지 못합니다. 이 기사에서는 PHP 자체에서 난수를 생성하는 안전한 방법에 대해 자세히 알아보고 비밀번호 잊어버린 문제를 해결합니다.
처음 제안된 솔루션은 다음과 같이 시드를 저장하고 호출할 때마다 이를 업데이트하는 것입니다.
result = seed seed = sha512(seed . mt_rand())
그러나 이 접근 방식에는 심각한 단점이 있습니다. sha512 기능은 마법처럼 엔트로피를 향상시키지 않으며 "mt_rand" 호출은 적을 저지하는 데 충분하지 않습니다. 대신 최신 운영 체제에서 제공하는 엔트로피 소스를 활용하는 것이 좋습니다.
다음은 안전한 128비트 랜덤을 생성하는 PHP 코드 조각입니다. 문자열:
$pr_bits = ''; if (file_exists("/dev/urandom")) { $fp = fopen('/dev/urandom','rb'); $pr_bits .= fread($fp, 16); fclose($fp); } elseif (class_exists('COM')) { try { $CAPI_Util = new COM('CAPICOM.Utilities.1'); $pr_bits .= $CAPI_Util->GetRandom(16, 0); if ($pr_bits) { $pr_bits = md5($pr_bits, TRUE); } } catch (Exception $ex) { // echo 'Exception: ' . $ex->getMessage(); } } if (strlen($pr_bits) < 16) { // Inform the administrator of the missing pseudorandom generator }
이식성을 극대화하려면 코드에 엔트로피 소스 시도를 모두 포함해야 합니다. 이 방법은 완벽하지는 않지만 초기 시드 기반 접근 방식에 비해 보안이 크게 향상되었습니다.
위 내용은 비밀번호 재설정과 같은 애플리케이션을 위해 PHP에서 난수를 어떻게 안전하게 생성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!