最近 uniqid を使用しているのですが、質問がありますか? uniqid によって生成される ID は何で構成されますか?本当にそれしかないのでしょうか?どのような状況で紛争が発生しますか?
uniqid 関数には 2 つのパラメーターがあることをドキュメントから確認してください
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 は 4 つの部分で構成されます:
prefix + sec + usec + “.” + php_combined_lcg
ここで、prefix は uniqid 関数の最初のパラメータです。これは文字列であり、渡されたものはすべて直接返されます。
sec は現在のクロックの秒、usec はミリ秒で、両方の値は gettimeofday から取得されます。つまり、1 台のマシン上にある限り、2 つの PHP プログラムによって同じミリ秒内に取得される sec と usec は同じになります。
php_combined_lcg は、uniqid の 2 番目のパラメータであるエントロピー値によって決定され、線形合同を使用して 0 ~ 1 の間の乱数を生成します。 2 番目のパラメータが true の場合はこの値があり、2 番目のパラメータが false の場合は値はありません。
例:
➜ ~ php -r 'echo uniqid("my_", true);'my_5afe9b414c2141.76621929
結論
したがって、パラメータを指定せずに単に uniqid() メソッドを使用する場合、このメソッドは単一のプロセスのみを保証できます。同じミリ秒です。 uniqid("", true) を使用する場合。エントロピー値を使用すると、生成される ID のランダム性を保証するランダムな方法がすでに備わっています。ただし、線形合同法は比較的単純な乱数生成アルゴリズムであるため、ランダム性が十分ではない可能性があるため、よりランダムな数値計算法がインターネット上で流通しています。線形合同を使用して乱数を生成する代わりに、メルセンヌ ツイスター乱数ジェネレーター (メセンヌ ツイスター アルゴリズム) を使用します。つまり、上記の ID は 2 つのランダム アルゴリズム + タイムスタンプによって生成されます。基本的に、このアルゴリズムはかなりの一意性を保証できます (競合率について尋ねたい場合、それを理解できるのは数学の学生だけであると推定されます...)。
上記の ID にはピリオドがあり、長さは 128 ビットではありません。 uuid を生成したい場合は、md5 または sha1 のハッシュが必要です。したがって、インターネット上で一意のコードを生成する別の方法があります。 (
php ビデオ チュートリアル