최근에 uniqid를 사용했는데 궁금한 점이 있나요? uniqid가 생성한 ID는 무엇으로 구성되나요? 정말 유일한 걸까요? 어떤 상황에서 갈등이 발생합니까?
문서에서 uniqid 함수에 두 개의 매개변수가 있음을 확인하세요.
uniqid의 구조
소스 코드를 보세요:
PHP_FUNCTION(uniqid) { ... gettimeofday((struct timeval *) &tv, (struct timezone *) NULL); sec = (int) tv.tv_sec; usec = (int) (tv.tv_usec % 0x100000); ... if (more_entropy) { uniqid = strpprintf(0, "%s%08x%05x%.8F", prefix, sec, usec, php_combined_lcg() * 10); } else { uniqid = strpprintf(0, "%s%08x%05x", prefix, sec, usec); } RETURN_STR(uniqid); }
기본적으로 명확하게 이해하세요. uniqid는 네 부분으로 구성됩니다:
prefix + sec + usec + “.” + php_combined_lcg
여기서 prefix는 uniqid 함수의 첫 번째 매개변수입니다. 이는 문자열이며 전달된 내용은 무엇이든 직접 반환됩니다.
sec는 현재 시계의 초이고 usec는 밀리초입니다. 두 값 모두 gettimeofday에서 가져옵니다. 즉, 하나의 시스템에 있는 한 동일한 밀리초 동안 두 개의 PHP 프로그램에서 얻은 sec와 usec는 동일합니다.
php_combined_lcg는 엔트로피 값인 uniqid의 두 번째 매개변수에 의해 결정됩니다. 이는 선형 합동을 사용하여 0과 1 사이의 난수를 생성합니다. 두 번째 매개변수가 true이면 이 값이 있습니다. 두 번째 매개변수가 false이면 값이 없습니다.
예:
➜ ~ php -r 'echo uniqid("my_", true);'my_5afe9b414c2141.76621929
결론
따라서 매개 변수 없이 단순히 uniqid() 메서드를 사용하면 이 메서드는 단일 프로세스가 동일한 밀리초 내에 고유하다는 것만 확인할 수 있습니다. uniqid("", true)를 사용하는 경우. 엔트로피 값을 사용하면 생성된 ID의 무작위성을 보장하는 무작위 방법이 이미 있습니다. 그러나 선형 합동은 난수를 생성하는 비교적 간단한 알고리즘이므로 난수성만으로는 충분하지 않을 수 있습니다. 따라서 인터넷에 유통되는 보다 난수적인 수치 방법은 다음과 같습니다.
uniqid(mt_rand(), true)
그중 mt_rand()는 선형을 사용하여 생성하지 않습니다. 난수를 합동적으로 생성하는 대신 Mersenne Twister 난수 생성기(Mersenne Twister Algorithm)를 사용합니다. 즉, 위의 id는 2개의 랜덤 알고리즘 + 타임스탬프를 통해 생성됩니다. 기본적으로 이 알고리즘은 고유성을 상당 부분 보장할 수 있다(충돌율을 물어보면 수학을 전공하는 학생들만이 알 수 있을 것으로 추정된다…).
위의 ID에는 마침표가 있으며 길이는 128비트가 아닙니다. uuid를 생성하려면 해시가 필요합니다. md5이든 sha1이든 선택할 수 있습니다. 따라서 인터넷에서 고유 코드를 생성하는 또 다른 방법이 있습니다. (php 비디오 튜토리얼)
md5(uniqid(mt_rand(), true))
그러나 본질적으로 두 방법의 무작위성은 동일합니다.
md5(uniqid(mt_rand(), true))--------- 개인적으로 이 효과가 좋다는 것을 간증합니다. 무겁지 않고 불규칙합니다------내 말
위 내용은 PHP의 uniqid 함수로 생성된 ID는 정말 고유합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 산 및 기본 데이터베이스 모델을 비교하여 특성과 적절한 사용 사례를 자세히 설명합니다. 산은 금융 및 전자 상거래 애플리케이션에 적합한 데이터 무결성 및 일관성을 우선시하는 반면 Base는 가용성 및

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

기사는 내장 함수 사용, 화이트리스트 접근 방식 및 서버 측 유효성 검사와 같은 기술에 중점을 둔 보안을 향상시키기 위해 PHP 입력 유효성 검증에 대한 모범 사례를 논의합니다.

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

이 기사에서는 PHP에서 암호를 보호하기 위해 PHP에서 Password_hash 및 Password_Verify 사용의 이점에 대해 설명합니다. 주요 주장은 이러한 기능이 자동 소금 생성, 강한 해싱 알고리즘 및 Secur를 통해 암호 보호를 향상 시킨다는 것입니다.

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 PHP의 XSS 공격을 방지하기위한 전략, 입력 소독, 출력 인코딩 및 보안 향상 라이브러리 및 프레임 워크 사용에 중점을 둔 전략에 대해 설명합니다.

이 기사는 각각의 사용시기에 중점을 둔 PHP의 인터페이스 및 추상 클래스 사용에 대해 설명합니다. 인터페이스는 관련없는 클래스 및 다중 상속에 적합한 구현없이 계약을 정의합니다. 초록 클래스는 일반적인 기능을 제공합니다


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

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

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
