php生成唯一ID的应用场景非常普遍,如临时缓存文件名称,临时变量,临时安全码等,uniqid()函数基于以微秒计的当前时间,生成一个唯一的 ID。由于生成唯一ID与微秒时间关联,因此ID的唯一性非常可靠。

生成的唯一ID默认返回的字符串有 13 个字符串长,如果再结合md5()函数,生成的唯一ID可靠性将更高,这种生成的ID比随机性的ID 最大优点在于可实现排序,特别是一些需要存储在数据库中的值。当然在这件也可以加入随机数。

我个人觉得还是手动的去处理生成唯一的id比较的好点,尽量降低生成id的重复概率。下面主要介绍4种生成唯一ID的方法,供大家参考。


1、md5(time() . mt_rand(1,1000000));

这种方法有一定的概率会出现重复


2、php内置函数uniqid()

uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 ID.

php 
echo uniqid(); 
echo uniqid(); 
echo uniqid(); 
?>
输出:
4bfd0e375396b
4bfd0e3753981
4bfd0e3753983

w3school参考手册有一句话:"由于基于系统时间,通过该函数生成的 ID 不是最佳的。如需生成绝对唯一的 ID,请使用 md5() 函数"。


3、结合md5()函数生成一个唯一ID

php 
echo md5(uniqid()); 
?>
输出:dfbc5c8c6438de075da28b3c8a413fd0


4、手动去处理,官方给予的案例。

public function create_guid($namespace = '') {  
  static $guid = '';
  $uid = uniqid("", true);
  $data = $namespace;
  $data .= $_SERVER['REQUEST_TIME'];
  $data .= $_SERVER['HTTP_USER_AGENT'];
  $data .= $_SERVER['LOCAL_ADDR'];
  $data .= $_SERVER['LOCAL_PORT'];
  $data .= $_SERVER['REMOTE_ADDR'];
  $data .= $_SERVER['REMOTE_PORT'];
  $hash = strtoupper(hash('ripemd128', $uid . $guid . md5($data)));
  $guid = '{' . 
      substr($hash, 0, 8) .
      '-' .
      substr($hash, 8, 4) .
      '-' .
      substr($hash, 12, 4) .
      '-' .
      substr($hash, 16, 4) .
      '-' .
      substr($hash, 20, 12) .
      '}';
  return $guid;
 }
 返回结果类似:E2DFFFB3-571E-6CFC-4B5C-9FEDAAF2EFD7