php生成隨機數(shù)的三種方法
如何用php生成1-10之間的不重復(fù)隨機數(shù)?
例1,使用shuffle函數(shù)生成隨機數(shù)。
<?php
$arr=range(1,10);
shuffle($arr);
foreach($arr as $values)
{
echo $values." ";
}
?>
例2,使用array_unique函數(shù)生成隨機數(shù)。
<?php
$arr=array();
while(count($arr)<10)
{
$arr[]=rand(1,10);
$arr=array_unique($arr);
}
echo implode(" ",$arr);
?>
例3,使用array_flip函數(shù)生成隨機數(shù),可以去掉重復(fù)值。
<?php
$arr=array();
$count1=0;
$count = 0;
$return = array();
while ($count < 10)
{
$return[] = mt_rand(1, 10);
$return = array_flip(array_flip($return));
$count = count($return);
} //www.dhdzp.com
foreach($return as $value)
{
echo $value." ";
}
echo "<br/>";
$arr=array_values($return);// 獲得數(shù)組的值
foreach($arr as $key)
echo $key." ";
?>
php隨機數(shù)生成函數(shù)示例
<?php
function randpw($len=8,$format='ALL'){
$is_abc = $is_numer = 0;
$password = $tmp ='';
switch($format){
case 'ALL':
$chars='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
break;
case 'CHAR':
$chars='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';
break;
case 'NUMBER':
$chars='0123456789';
break;
default :
$chars='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
break;
} // www.dhdzp.com
mt_srand((double)microtime()*1000000*getmypid());
while(strlen($password)<$len){
$tmp =substr($chars,(mt_rand()%strlen($chars)),1);
if(($is_numer <> 1 && is_numeric($tmp) && $tmp > 0 )|| $format == 'CHAR'){
$is_numer = 1;
}
if(($is_abc <> 1 && preg_match('/[a-zA-Z]/',$tmp)) || $format == 'NUMBER'){
$is_abc = 1;
}
$password.= $tmp;
}
if($is_numer <> 1 || $is_abc <> 1 || empty($password) ){
$password = randpw($len,$format);
}
return $password;
}
for($i = 0 ; $i < 10; $i++){
echo randpw(8,'NUMBER');
echo "<br>";
}
PS:最后再為大家提供兩款相關(guān)在線工具供大家參考使用:
在線隨機數(shù)字/字符串生成工具:
http://tools.jb51.net/aideddesign/suijishu
高強度隨機密碼生成器:
http://tools.jb51.net/password/CreateStrongPassword
相關(guān)文章
PHP5.5在windows安裝使用memcached服務(wù)端的方法
這篇文章主要介紹了PHP5.5在windows安裝使用memcached服務(wù)端的方法,需要的朋友可以參考下2014-04-04
PHP實現(xiàn)通過Luhn算法校驗信用卡卡號是否有效
這篇文章主要介紹了PHP實現(xiàn)通過Luhn算法校驗信用卡卡號是否有效,實例分析了php實現(xiàn)Luhn算法及相關(guān)應(yīng)用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03
php實現(xiàn)把數(shù)組按指定的個數(shù)分隔
這篇文章主要介紹了php實現(xiàn)把數(shù)組按指定的個數(shù)分隔。需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02
php將HTML表格每行每列轉(zhuǎn)為數(shù)組實現(xiàn)采集表格數(shù)據(jù)的方法
這篇文章主要介紹了php將HTML表格每行每列轉(zhuǎn)為數(shù)組實現(xiàn)采集表格數(shù)據(jù)的方法,涉及php正則替換的技巧,非常具有實用價值,需要的朋友可以參考下2015-04-04

