Php 生成要附加到url后面的唯一ID

Php 生成要附加到url后面的唯一ID,php,unique-key,Php,Unique Key,我发现下面的PHP函数非常好用,但我没有足够的用户声誉在该页面上发表评论并寻求帮助,所以我提出了一个新问题 假设我使用下面代码中的函数生成一个6或8个字符的密钥,这个函数生成同一个密钥两次的可能性有多大?是每千/百万/十亿次一次吗 谢谢 function crypto_rand_secure($min, $max) { $range = $max - $min; if ($range < 0) return $min; // not so random...

我发现下面的PHP函数非常好用,但我没有足够的用户声誉在该页面上发表评论并寻求帮助,所以我提出了一个新问题

假设我使用下面代码中的函数生成一个6或8个字符的密钥,这个函数生成同一个密钥两次的可能性有多大?是每千/百万/十亿次一次吗

谢谢

function crypto_rand_secure($min, $max) {
        $range = $max - $min;
        if ($range < 0) return $min; // not so random...
        $log = log($range, 2);
        $bytes = (int) ($log / 8) + 1; // length in bytes
        $bits = (int) $log + 1; // length in bits
        $filter = (int) (1 << $bits) - 1; // set all lower bits to 1
        do {
            $rnd = hexdec(bin2hex(openssl_random_pseudo_bytes($bytes)));
            $rnd = $rnd & $filter; // discard irrelevant bits
        } while ($rnd >= $range);
        return $min + $rnd;
}

function getToken($length){
    $token = "";
    $codeAlphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    $codeAlphabet.= "abcdefghijklmnopqrstuvwxyz";
    $codeAlphabet.= "0123456789";
    for($i=0;$i<$length;$i++){
        $token .= $codeAlphabet[crypto_rand_secure(0,strlen($codeAlphabet))];
    }
    return $token;
}
函数加密和安全($min,$max){
$range=$max-$min;
如果($range<0)返回$min;//不太随机。。。
$log=log($range,2);
$bytes=(int)($log/8)+1;//字节长度
$bits=(int)$log+1;//以位为单位的长度
$filter=(int)(1=$range);
返回$min+$rnd;
}
函数getToken($length){
$token=“”;
$codeAlphabet=“abcdefghijklmnopqrstuvxyz”;
$codeAlphabet.=“abcdefghijklmnopqrstuvwxyz”;
$codeAlphabet.=“0123456789”;

对于($i=0;$i如果您只需要一个唯一的ID,您可以使用
uniqid()
函数。

这完全取决于您使用的最小值和最大值。当有几个内置函数生成唯一ID时,为什么要重新发明轮子,而冲突可能会更少…cfr
uniqid()
com\u create\u guid()
,…谢谢,在查看了我使用的uniqid()函数之后: