> php教程 > php >

php生成随机数的3种方法

来源:网络 文章列表 2019-05-15 8
php随机数主要是使用rand、mt_rand这2个函数。当然我们还可以自定义一切方法,比如设置字母a-z,或者取当前时间戳。下面我们就一起总结下吧!

php随机数主要是使用rand、mt_rand这2个函数。当然我们还可以自定义一切方法,比如设置字母a-z,或者取当前时间戳。下面我们就一起总结下吧!

php rand() 函数

返回随机整数。

语法:   rand(min,max)

参数说明:如果没有提供可选参数 minmax,rand() 返回 0 到 RAND_MAX 之间的伪随机整数。例如,想要 5 到 15(包括 5 和 15)之间的随机数,用 rand(5, 15)。

注意:

在某些平台下(例如 Windows)RAND_MAX 只有 32768。如果需要的范围大于 32768,那么指定 min 和 max 参数就可以生成大于 RAND_MAX 的数了,或者考虑用 mt_rand() 来替代它。

例子:

echo rand();  // 生成 0~RAND_MAX 之间的随机数,Windows 系统下 RAND_MAX 的值为 32767,RAND_MAX 可以用函数 getrandmax()获得

echo rand(1000000, 9999999);// 生成 1000000~9999999 之间的随机数

$seed = time();// 使用时间作为种子源

srand($seed);// 播下随机数发生器种子

echo rand();// 根据种子生成 0~32768 之间的随机数。如果 $seed 值固定,则生成的随机数也不变

echo rand(1000000, 9999999); // 根据种子生成 1000000~9999999 之间的随机数。如果 $seed 值固定,则生成的随机数也不变

 

php mt_rand函数

mt_rand是rand的加强版。

mt_rand() 是使用 Mersenne Twister 算法返回随机整数,与 rand() 函数的主要区别是:

mt_rand()产生随机数值的平均速度比 libc 提供的 rand() 快四倍,并且播种函数使用mt_srand(),而不是srand()。虽然有这点区别,但是它们的使用方法还是相似的,如下:

echo mt_rand();// 生成 0~RAND_MAX 之间的随机数,Windows 系统下 RAND_MAX 的值为 2147483647(与rand()中的 RAND_MAX 不同),RAND_MAX 可以用函数 mt_getrandmax() 获得
echo mt_rand(1000000, 9999999);   // 生成 1000000~9999999 之间的随机数,不受系统 RAND_MAX 影响

$seed = time(); // 使用时间作为种子源

mt_srand($seed); // 播下随机数发生器种子

echo rand();// 根据种子生成 0~RAND_MAX 之间的随机数,如果 $seed 值固定,则生成的随机数也不变

echo rand(1000000, 9999999);// 根据种子生成 1000000~9999999 之间的随机数,如果 $seed 值固定,则生成的随机数也不变

注意:

1、rand() 和 mt_rand() 两个函数生成的随机数都是整数,不会包含英文字母

2、mt_rand()比rand()快四倍

 

php uniqid函数生成随机数

uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 ID。默认生成ID的长度为13位或者23位,由英文字母和数字组成。uniqid() 函数有两个参数,格式如下:

uniqid(prefix,more_entropy)

其中,

  • prefix:生成ID的前缀
  • more_entropy:是否添加额外的熵

如下的程序

echo uniqid();// 生成13位字符串,如:55f540e273e93
echo uniqid('one.'); // 生成前缀为one.加13位随机字符的字符串,如:one.55f540e273e93
echo uniqid('two.', true);// 生成前缀为two.加23位随机字符的字符串(加了熵),如:two.55f540e273e932.77804707,比上面的多了 10 位,即多了:2.77804707

说明:由于基于系统时间,通过该函数生成的 ID 不是最佳的。如需生成绝对唯一的 ID,请使用 md5() 函数。

例如:

function get_password( $length = 8 ) 
{
    $str = substr(md5(time()), 0, $length);//md5加密,time()当前时间戳
    return $str;
}

 

根据给定的字母取随机数,比如生成验证码

function getrandstr(){
  $str='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890';
  $randStr = str_shuffle($str);//打乱字符串
  $rands= substr($randStr,0,6);//substr(string,start,length);返回字符串的一部分
  return $rands;
}

 

版权声明

本站部分原创文章,部分文章整理自网络。如有转载的文章侵犯了您的版权,请联系站长删除处理。如果您有优质文章,欢迎发稿给我们!联系站长:
愿本站的内容能为您的学习、工作带来绵薄之力。

评论

  • 随机获取
点击刷新
精彩评论

友情链接