PHP乱数の原理

(*-*)浩
(*-*)浩オリジナル
2019-09-09 11:43:492663ブラウズ

php 乱数の原理:

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 .= &#39;`~!@#$%^&*()_+-=[]{};:"|,.<>/?&#39;;
$str=substr(str_shuffle($chars),0,10);    //10位随机数
//中英文混合随机可以会出现乱码因为str_shuffle是基于字符随机打乱
//不能直接使用str_split函数,因为该函数也是基于字符串的
//PS:疯狂吐槽中文
function mb_str_split($str){    //切割中文字符串
    return preg_split(&#39;/(?<!^)(?!$)/u&#39;, $str );
}
$chars.=&#39;你好歹还得发哈收到付款将很快经过艰苦规划&#39;;
$chars=mb_str_split($chars);
//可以使用数组随机数array_rand(array,number)

以上がPHP乱数の原理の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。