首页 > 开发 > PHP > 正文

php生成唯一数字id的方法汇总

2024-05-04 23:40:28
字体:
来源:转载
供稿:网友

我们在平时的项目中,经常会遇到要使用php生成唯一数字id的环境,网上查了很多资料,其实还是有一定的可能性重复的,所以今天在这里分享下,个人最近研究这个问题的所得。

关于生成唯一数字ID的问题,是不是需要使用rand生成一个随机数,然后去数据库查询是否有这个数呢?感觉这样的话有点费时间,有没有其他方法呢?

当然不是,其实有两种方法可以解决。

1. 如果你只用php而不用数据库的话,那时间戳+随机数是最好的方法,且不重复;

2. 如果需要使用数据库,即你还需要给这个id关联一些其他的数据。那就给MySQL数据库中的表的id一个AUTO_INCREMENT(自增)属性,每次插入一条数据时,id自动+1,然后使用mysql_insert_id()或LAST_INSERT_ID()返回这个自增后的id。

当然,这个问题已经有现成的解决方法了,使用php uuid扩展就能完美解决这个问题,这个扩展能生成唯一的完全数字签名。。

如果你不使用composer请参考https://github.com/lootils/uuid,

如果你的项目是基于composer搭建的,那么请参考https://github.com/ramsey/uuid

具体的源码我就不搬运了,小伙伴们自己取下来就可以直接使用了

PHP生成唯一标识符代码示例:

 

 
  1. < ?  
  2. //生成唯一标识符  
  3. //sha1()函数, "安全散列算法(SHA1)"  
  4. function create_unique() {  
  5. $data = $_SERVER['HTTP_USER_AGENT'] . $_SERVER['REMOTE_ADDR']  
  6. .time() . rand();  
  7. return sha1($data);  
  8. //return md5(time().$data);  
  9. //return $data;  
  10. }  
  11. ?>  

PHP生成唯一标识符函数描述及例子

 

 
  1. < ?  
  2. $newhash = create_unique();  
  3. echo $newhash;  
  4. ?> 

再给大家分享一个

 

 
  1. /* 
  2. * 信号量(Semaphore)。 
  3. * 这是一个包装类,用于解决不同平台下对“信号量”的不同实现方式。 
  4. * 目前这个类只是象征性的,在 Windows 平台下实际是空跑(并没有真的实现互斥)。 
  5. */ 
  6. class SemWrapper 
  7. private $hasSemSupport; 
  8. private $sem; 
  9. const SEM_KEY = 1; 
  10.  
  11. public function __construct() 
  12. $this->hasSemSupport = function_exists( 'sem_get' ); 
  13. if ( $this->hasSemSupport ) { 
  14. $this->sem = sem_get( self::SEM_KEY ); 
  15.  
  16. public function acquire() { 
  17. if ( $this->hasSemSupport ) { 
  18. return sem_acquire( $this->sem ); 
  19. return true
  20.  
  21. public function release() { 
  22. if ( $this->hasSemSupport ) { 
  23. return sem_release( $this->sem ); 
  24. return true
  25.  
  26. /* 
  27. * 顺序号发生器。 
  28. */ 
  29. class SeqGenerator 
  30. const SHM_KEY = 1; 
  31.  
  32. /** 
  33. * 对顺序号发生器进行初始化。 
  34. * 仅在服务器启动后的第一次调用有效,此后再调用此方法没有实际作用。 
  35. * @param int $start 产生顺序号的起始值。 
  36. * @return boolean 返回 true 表示成功。 
  37. */ 
  38. static public function init( $start = 1 ) 
  39. // 通过信号量实现互斥,避免对共享内存的访问冲突 
  40. $sw = new SemWrapper; 
  41. if ( ! $sw->acquire() ) { 
  42. return false
  43.  
  44. // 打开共享内存 
  45. $shm_id = shmop_open( self::SHM_KEY, 'n', 0644, 4 ); 
  46. if ( empty($shm_id) ) { 
  47. // 因使用了 'n' 模式,如果无法打开共享内存,可以认为该共享内存已经创建,无需再次初始化 
  48. $sw->release(); 
  49. return true
  50.  
  51. // 在共享内存中写入初始值 
  52. $size = shmop_write( $shm_id, pack( 'L', $start ), 0 ); 
  53. if ( $size != 4 ) { 
  54. shmop_close( $shm_id ); 
  55. $sw->release(); 
  56. return false
  57.  
  58. // 关闭共享内存,释放信号量 
  59. shmop_close( $shm_id ); 
  60. $sw->release(); 
  61. return true
  62.  
  63. /** 
  64. * 产生下一个顺序号。 
  65. * @return int 产生的顺序号 
  66. */ 
  67. static public function next() 
  68. // 通过信号量实现互斥,避免对共享内存的访问冲突 
  69. $sw = new SemWrapper; 
  70. if ( ! $sw->acquire() ) { 
  71. return 0; 
  72.  
  73. // 打开共享内存 
  74. $shm_id = shmop_open( self::SHM_KEY, 'w', 0, 0 ); 
  75. if ( empty($shm_id) ) { 
  76. $sw->release(); 
  77. return 0; 
  78.  
  79. // 从共享内存中读出顺序号 
  80. $data = shmop_read( $shm_id, 0, 4 ); 
  81. if ( empty($data) ) { 
  82. $sw->release(); 
  83. return 0; 
  84.  
  85. $arr = unpack( 'L', $data ); 
  86. $seq = $arr[1]; 
  87.  
  88. // 把下一个顺序号写入共享内存 
  89. $size = shmop_write( $shm_id, pack( 'L', $seq + 1 ), 0 ); 
  90. if ( $size != 4 ) { 
  91. $sw->release(); 
  92. return 0; 
  93.  
  94. // 关闭共享内存,释放信号量 
  95. shmop_close( $shm_id ); 
  96. $sw->release(); 
  97. return $seq; 
  98.  
  99. $a = SeqGenerator::init( time() ); 
  100. var_dump($a); 
  101.  
  102. for ( $i=0; $i < 10; $i++ ) { 
  103. $seq = SeqGenerator::next(); 
  104. var_dump($seq); 

好了,今天就先到这里吧,希望对大家学习PHP能够有所帮助


注:相关教程知识阅读请移步到PHP教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表