보안 대 성능 임의 숫자 생성 :`random_int ()`vs.`mt_rand ()`
토큰, 암호 및 소금과 같은 보안 민감성 작업에는 Random_int ()를 사용하여 암호화 적으로 안전하기 때문에 /dev /urandom 또는 cryptgenrandom과 같은 OS 수준 엔트로피 소스에 의존하기 때문입니다. 2. 속도가 중요하고 예측 가능성이 빠르고 예측 가능한 Mersenne Twister 알고리즘을 사용하기 때문에 게임, 시뮬레이션 또는 배열 셔플 링과 같은 비 보안 목적으로 mt_rand ()를 사용하십시오. 3. 예측할 수없는 것이 필요한 경우 mt_rand ()를 사용하지 않으므로 리버스 엔지니어링 할 수 있으므로 Random_int ()는 보안이 성능 요구를 능가하는 경우 안전과 효율성 사이의 올바른 균형을 보장하는 경우에 예약되어야합니다.
PHP에서 임의의 숫자를 생성 할 때 random_int()
와 mt_rand()
중에서 선택하면 보안 과 성능 사이의 상충 관계가 있습니다. 두 기능 모두 임의의 정수를 생성하지만, 다른 목적을 수행하며 모든 상황에서 상호 교환 할 수는 없습니다.

? 보안 : random_int()
암호화 적으로 안전합니다
random_int()
는 PHP 7.0에 특히 암호적으로 안전한 임의의 정수를 제공하기 위해 도입되었습니다. 운영 체제가 제공하는 안전한 임의 소스를 사용합니다.
- Linux :
/dev/urandom
또는getrandom()
시스템 호출 - Windows :
CryptGenRandom
또는BCryptGenRandom
- 기타 시스템 : 동등한 CSPRNG (암호적으로 보안 의사 숫자 생성기)
이것은 random_int()
에 적합합니다.

- 세션 토큰 생성
- 비밀번호 재설정 키 생성
- CSRF 토큰 생산
- 예측 가능성을 이용할 수있는 모든 시나리오
$ token = bin2Hex (random_int (100000, 999999)); // 보안에 민감한 사용에 안전합니다
OS 레벨 엔트로피에 의존하기 때문에 random_int()
특히 고 부하 또는 엔트로피가 제한된 시스템에서 mt_rand()
보다 느립니다 .
성능 : mt_rand()
는 빠르지 만 안전하지 않습니다
mt_rand()
비 보안 목적에 우수한 빠르고 신뢰할 수있는 PRNG (Pseudorandom 번호 생성기) 인 Mersenne Twister 알고리즘을 사용합니다.

이상적입니다.
- 셔플 링 어레이
- 시뮬레이션 또는 게임
- 페이지 매김이 상쇄됩니다
- 속도와 보안이 중요하지 않은 경우
$ random_index = mt_rand (0, count ($ aftem) -1);
그러나 mt_rand()
는 예측 가능합니다 . 충분한 출력이 주어지면 공격자는 내부 상태를 역전시키고 향후 값을 예측할 수 있습니다. 따라서 보안 관련 작업에는 적합하지 않습니다 .
또한 참고 :
-
mt_rand()
수동으로 시드해야합니다 (PHP는 처음 사용하면 자동으로이를 수행하지만) - 무작위성은 통계적으로 우수하지만 암호적으로 강하지 않습니다
-
random_int()
보다 훨씬 빠릅니다.
언제 어느 것을 사용해야합니까?
유스 케이스 | 권장 기능 |
---|---|
보안 토큰, 암호, 소금 | ✅ random_int() |
게임 메커니즘, 랜덤 샘플링 | mt_rand() |
세션 ID 또는 API 키 | ✅ random_int() |
성능 루프 | mt_rand() |
사용자를 향한 것이지만 비밀은 아닙니다 | mt_rand() |
? 공격자에게는 예측할 수없는 모든 것에 대해
mt_rand()
사용하지 마십시오.
실제 예 : 벤치 마크 비교
$ start = microtime (true); for ($ i = 0; $ i <10000; $ i) { mt_rand (1, 1000); } echo "mt_rand () :". (마이크로 타임 (True) - $ 시작). "초 \ n"; $ start = microtime (true); for ($ i = 0; $ i <10000; $ i) { random_int (1, 1000); } echo "random_int () :". (마이크로 타임 (True) - $ 시작). "초 \ n";
일반적으로 mt_rand()
가 5-10x 더 빠르게 실행됩니다.
결론
- 보안이 발생할 때
random_int()
사용하십시오. - 속도와 통계 무작위성이 필요할 때
mt_rand()
사용하면 착취의 위험이 없습니다 .
올바른 기능을 선택하는 것은 전반적으로 "더 나은"것이 아닙니다. 도구를 작업과 일치시키는 것입니다. 안전한 컨텍스트에서 mt_rand()
잘못 사용하면 심각한 취약점이 발생할 수 있으며 성능 크리티컬 코드에서 random_int()
과도하게 사용하면 불필요한 오버 헤드가 추가 될 수 있습니다.
기본적으로 : 가능한 경우 금식해야 할 때 안전합니다.
위 내용은 보안 대 성능 임의 숫자 생성 :`random_int ()`vs.`mt_rand ()`의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

bcmathissessentialforaccuratecryptocurrencyculationsinphpbecausefloating-pointarithmeticintructionceptaberoundingercations.1.Floating-pointnumbers like0.1 0.2yieldimprecessults (예 : 0.3000000000000004)

플로팅 포인트 수는 부정확합니다. PHP에서는 일반적인 문제입니다. 대답은 IEEE754 이중 프리즈 형식을 사용하여 소수점 소수를 정확하게 표현할 수 없게 만듭니다. 1.0.1 또는 0.2와 같은 숫자는 이진의 무한 루프 소수이며 컴퓨터는 오류를 일으키기 위해 잘라야합니다. 2. 부동 소수점 번호를 비교할 때는 abs ($ a- $ b)와 같은 == 대신 공차를 사용해야합니다.

Round ()는 "Roundhalftoeven"을 사용하고 "Roundhalfup"을 사용하고 Soround (2.5) Returns2andround (3.5) returns4tominimizestatisticalbias, thatmaysurprisoSeExpectingTraditionArounding.2

ModularArithmeticEssentialInphPcryptographicapplicationsESpitepHpnotbeingahigh-performancelanguage; 2.itunderpinspublic-keysystemslikersaanddiffie-hellmanthrougherationssuchasmodularexponentiationandinvers;

평균 계산 : Array_Sum ()을 사용하여 요소 수로 나뉘어 평균을 얻습니다. 2. 중앙값 계산 : 정렬 후 중간 값을 취하고 요소가있을 때 두 개의 중간 숫자의 평균을 취하십시오. 3. 표준 편차 계산 : 먼저 평균을 찾은 다음 각 값과 평균 사이의 제곱 차이의 평균을 계산하고 (샘플은 N-1) 마지막으로 제곱근을 취합니다. 이 세 가지 기능을 캡슐화함으로써, 기본 통계 도구를 구성하고, 중소형 데이터 분석에 적합하고, 빈 배열 및 비수막 입력 처리에주의를 기울이고, 외부 라이브러리에 의존하지 않고 데이터의 핵심 통계적 기능을 실현할 수 있습니다.

avectorinphpgraphicsRespresentSentspositions, 방향, orvelocityUsingAclass -likevector3dwithx, y, zcomponents.2.basicoperationsincludeaddition, subtraction, scalarmultiplication 및 divisionformovementandscaling.3.magnitudeIscalcatedviatheythoreantheorem, a

gmpissentialforhandlinglargeintegersinphpbeyondnativelimits.1.gmpenablestrary-precisionintegerarithicusingoptimizedclibraries, unlikenativeintegersthatoverflowflowflowfflowertovestring rastring.2.usegmpforHeavyInggerationsiving-undercatorial

gmpisessentialforhandlinglargenumbersinphpthatexceatexceptexexectexexectextintegerlimits, suchasinfactorialandfibonaccicalculations, 여기서 1Itenablestrary-precisionArithmeticEforAccurateStults;
