php随机数原理:
系统自动生成一个随机数种子(mt_srand函数可以自己生成种子),mt_rand先判断是否有生成种子,没有就自动生成一个,然后根据种子生成随机数。
生成10000-99999随机数字:(推荐学习:PHP编程从入门到精通)
mt_rand(10000,99999); //php提供的随机数为伪随机数(计算机只能生成伪随机数,php英文文档上有警告此随机数不要使用于token生成的操作) //伪随机是由可确定的函数(常用线性同余),通过一个种子(常用时钟),产生的伪随机数。
登录后复制
一个小实验:
mt_srand(10); //播种随机数种子 echo mt_rand(1,100).PHP_EOL; //生成随机数 echo mt_rand(1,100).PHP_EOL; //生成随机数 //然后你会发现无论你怎么刷新网页,生成的随机数都是一样的!! //建议使用openssl_random_pseudo_bytes生成token
登录后复制
爆破出随机数种子,利用工具php_mt_srand
生成字符串随机数:
$chars = 'abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'; $chars .= '`~!@#$%^&*()_+-=[]{};:"|,.<>/?'; $str=substr(str_shuffle($chars),0,10); //10位随机数 //中英文混合随机可以会出现乱码因为str_shuffle是基于字符随机打乱 //不能直接使用str_split函数,因为该函数也是基于字符串的 //PS:疯狂吐槽中文 function mb_str_split($str){ //切割中文字符串 return preg_split('/(?<!^)(?!$)/u', $str ); } $chars.='你好歹还得发哈收到付款将很快经过艰苦规划'; $chars=mb_str_split($chars); //可以使用数组随机数array_rand(array,number)
登录后复制
以上就是php随机数原理的详细内容,更多请关注Work网其它相关文章!