최근에 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!