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;