1、  使用md5加密数字;

 

举例:

   <?php

echomd5(time().mt_rand(1,10000000));

?>

输出结果为:

e9e169d023dld5e349c9a55c01f4

 

这种方法有一定的概率重复,因为仅仅是基于时间戳和随机数的,如果在同一秒内经过太过次的运行,导致随机数一样的话,输出结果会是一样的

 

 

2、  使用php内置函数uniqid();

 

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

 

但是在w3chool参考文献中有一个提示和注释:由于基于系统时间,通过

该函数生成的ID不是最佳的。如需生成绝对唯一的ID,请使用md5()函数。

(参考文献地址:http://www.w3school.com.cn/php/func_misc_uniqid.asp

 

 

3、  根据guid生成,虽然php官方没有内置的guid函数,但是可以自己封装。

 

代码如下:

   functionguid($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;

  }

         此方法是把$uid,$guid,时间戳的MD5加密结果组合在一起,再次用非对称加密hash经过128位加密而成,其重复的概率无限接近为0