如何在PHP中生成隨機數(shù)
第一種方法用mt_rand()
function GetRandStr($length){ $str='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; $len=strlen($str)-1; $randstr=''; for($i=0;$i<$length;$i++){ $num=mt_rand(0,$len); $randstr .= $str[$num]; } return $randstr; } $number=GetRandStr(6); echo $number;
第二種方法(最快的)
function make_password( $length = 8 ) { // 密碼字符集,可任意添加你需要的字符 $chars = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l','m', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y','z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L','M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y','Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!', '@','#', '$', '%', '^', '&', '*', '(', ')', '-', '_', '[', ']', '{', '}', '<', '>', '~', '`', '+', '=', ',', '.', ';', ':', '/', '?', '|'); // 在 $chars 中隨機取 $length 個數(shù)組元素鍵名 $keys = array_rand($chars, $length); $password = ''; for($i = 0; $i < $length; $i++) { // 將 $length 個數(shù)組元素連接成字符串 $password .= $chars[$keys[$i]]; } return $password; }
第三種取當時時間戳
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; }
第五種開始創(chuàng)建驗證碼(直接用函數(shù)生成,比較方便快捷)
$code = rand(10000, 99999);
php mt_rand生成0~1隨機小數(shù)的效果比較
lcg_value說明
float lcg_value ( void )
lcg_value()
返回范圍為 (0, 1) 的一個偽隨機數(shù)。本函數(shù)組合了周期為 2^31 - 85 和 2^31 - 249 的兩個同余發(fā)生器。本函數(shù)的周期等于這兩個素數(shù)的乘積。
返回:范圍為 (0, 1) 的偽隨機數(shù)。
<?php for($i=0; $i<5; $i++){ echo lcg_value().PHP_EOL; } ?>
輸出:
0.11516515851995
0.064684551575297
0.68275174031189
0.55730746529099
0.70215008878091
兩種生成0~1隨機小數(shù)方法進行比較
1.執(zhí)行時間比較
執(zhí)行10萬次基于mt_rand()
與mt_getrandmax()
算法的運行時間
<?php /** * 生成0~1隨機小數(shù) * @param Int $min * @param Int $max * @return Float */ function randFloat($min=0, $max=1){ return $min + mt_rand()/mt_getrandmax() * ($max-$min); } // 獲取microtime function get_microtime(){ list($usec, $sec) = explode(' ', microtime()); return (float)$usec + (float)$sec; } // 記錄開始時間 $starttime = get_microtime(); // 執(zhí)行10萬次獲取隨機小數(shù) for($i=0; $i<100000; $i++){ randFloat(); } // 記錄結(jié)束時間 $endtime = get_microtime(); // 輸出運行時間 printf("run time %f ms\r\n", ($endtime-$starttime)*1000); ?>
輸出:
run time 266.893148 ms
執(zhí)行10萬次lcg_value()
的運行時間
<?php // 獲取microtime function get_microtime(){ list($usec, $sec) = explode(' ', microtime()); return (float)$usec + (float)$sec; } // 記錄開始時間 $starttime = get_microtime(); // 執(zhí)行10萬次獲取隨機小數(shù) for($i=0; $i<100000; $i++){ lcg_value(); } // 記錄結(jié)束時間 $endtime = get_microtime(); // 輸出運行時間 printf("run time %f ms\r\n", ($endtime-$starttime)*1000); ?>
輸出:
run time 86.178064 ms
執(zhí)行時間上比較,因為lcg_value()
直接是php原生方法,而mt_rand()
與mt_getrandmax()
需要調(diào)用兩個方法,并需要進行計算,因此lcg_value()
的執(zhí)行時間大約快3倍。
2.隨機效果比較
基于mt_rand()
與mt_getrandmax()
算法的隨機效果
<?php /** * 生成0~1隨機小數(shù) * @param Int $min * @param Int $max * @return Float */ function randFloat($min=0, $max=1){ return $min + mt_rand()/mt_getrandmax() * ($max-$min); } header('content-type: image/png'); $im = imagecreatetruecolor(512, 512); $color1 = imagecolorallocate($im, 255, 255, 255); $color2 = imagecolorallocate($im, 0, 0, 0); for($y=0; $y<512; $y++){ for($x=0; $x<512; $x++){ $rand = randFloat(); if(round($rand,2)>=0.5){ imagesetpixel($im, $x, $y, $color1); }else{ imagesetpixel($im, $x, $y, $color2); } } } imagepng($im); imagedestroy($im); ?>
lcg_value()
的隨機效果
<?php header('content-type: image/png'); $im = imagecreatetruecolor(512, 512); $color1 = imagecolorallocate($im, 255, 255, 255); $color2 = imagecolorallocate($im, 0, 0, 0); for($y=0; $y<512; $y++){ for($x=0; $x<512; $x++){ $rand = lcg_value(); if(round($rand,2)>=0.5){ imagesetpixel($im, $x, $y, $color1); }else{ imagesetpixel($im, $x, $y, $color2); } } } imagepng($im); imagedestroy($im); ?>
3.隨機閱讀推薦
+ php給源碼加密的方法總結(jié):http://www.dbjr.com.cn/article/134506.html
以上就是如何在PHP中生成隨機數(shù)的詳細內(nèi)容,更多關(guān)于PHP隨機數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
優(yōu)化WordPress的Google字體以加速國內(nèi)服務(wù)器上的運行
這篇文章主要介紹了優(yōu)化WordPress的Google字體以加速國內(nèi)服務(wù)器上的運行的方法,由于谷歌在內(nèi)地被墻導致其更新等方面都收到不同程度的影響,需要的朋友可以參考下2015-11-11PHP實現(xiàn)搜索地理位置及計算兩點地理位置間距離的實例
這篇文章主要介紹了PHP實現(xiàn)搜索地理位置及計算兩點地理位置間距離的實例,地理位置搜尋的例子中使用到了MongoDB數(shù)據(jù)庫,需要的朋友可以參考下2016-01-01基于jQueryUI和Corethink實現(xiàn)百度的搜索提示功能
這篇文章主要介紹了基于jQueryUI和Corethink實現(xiàn)百度的搜索提示功能,這里是以corethink模塊的形式,只需要安裝上訪問index.php?s=/test/index 就可以了,需要的朋友可以參考下2016-11-11ThinkPHP框架基于PDO方式連接數(shù)據(jù)庫操作示例
這篇文章主要介紹了ThinkPHP框架基于PDO方式連接數(shù)據(jù)庫操作,結(jié)合完整實例形式分析了thinkPHP使用PDO方式連接數(shù)據(jù)庫的相關(guān)配置、控制器及模板調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2018-03-03