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隨機數字原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!