標籤:col func ret php_eol tran password start create eset
第一種方法用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 個數組元素鍵名 $keys = array_rand($chars, $length); $password = ‘‘; for($i = 0; $i < $length; $i++) { // 將 $length 個數組元素串連成字串 $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;}
5 //開始建立驗證碼(直接用函數產生,比較方便快捷)
$code = rand(10000, 99999);
php mt_rand產生0~1隨機小數的效果比較
lcg_value說明
float lcg_value ( void )
lcg_value() 返回範圍為 (0, 1) 的一個偽隨機數。本函數組合了周期為 2^31 - 85 和 2^31 - 249 的兩個同餘發生器。本函數的周期等於這兩個素數的乘積。
返回:範圍為 (0, 1) 的偽隨機數。
<?phpfor($i=0; $i<5; $i++){ echo lcg_value().PHP_EOL;}?>
輸出:
0.11516515851995
0.064684551575297
0.68275174031189
0.55730746529099
0.70215008878091
兩種產生0~1隨機小數方法進行比較
1.執行時間比較
執行10萬次基於mt_rand()與mt_getrandmax()演算法的已耗用時間
<?php/** * 產生0~1隨機小數 * @param Int $min * @param Int $max * @return Float */function randFloat($min=0, $max=1){ return $min + mt_rand()/mt_getrandmax() * ($max-$min);} // 擷取microtimefunction get_microtime(){ list($usec, $sec) = explode(‘ ‘, microtime()); return (float)$usec + (float)$sec;} // 記錄開始時間$starttime = get_microtime(); // 執行10萬次擷取隨機小數for($i=0; $i<100000; $i++){ randFloat();} // 記錄結束時間$endtime = get_microtime(); // 輸出已耗用時間printf("run time %f ms\r\n", ($endtime-$starttime)*1000);?>
輸出:run time 266.893148 ms
執行10萬次lcg_value()的已耗用時間
<?php// 擷取microtimefunction get_microtime(){ list($usec, $sec) = explode(‘ ‘, microtime()); return (float)$usec + (float)$sec;} // 記錄開始時間$starttime = get_microtime(); // 執行10萬次擷取隨機小數for($i=0; $i<100000; $i++){ lcg_value();} // 記錄結束時間$endtime = get_microtime(); // 輸出已耗用時間printf("run time %f ms\r\n", ($endtime-$starttime)*1000);?>
輸出:run time 86.178064 ms
執行時間上比較,因為lcg_value()直接是php原生方法,而mt_rand()與mt_getrandmax()需要調用兩個方法,並需要進行計算,因此lcg_value()的執行時間大約快3倍。
2.隨機效果比較
基於mt_rand()與mt_getrandmax()演算法的隨機效果
<?php/** * 產生0~1隨機小數 * @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()的隨機效果
<?phpheader(‘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);?>
PHP產生隨機數的幾種方法