原理很簡單,先寫一個函數,生成0-z這36個字符中的一個。每次調用 getOptions() 方法生成一個字符,它們的存儲如下:array[0] = 0, array[1] = 1, ……, array[35] = z。
Array ( [0] => 0 [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 5 [6] => 6 [7] => 7 [8] => 8 [9] => 9 [10] => a [11] => b [12] => c [13] => d [14] => e [15] => f [16] => g [17] => h [18] => i [19] => j [20] => k [21] => l [22] => m [23] => n [24] => o [25] => p [26] => q [27] => r [28] => s [29] => t [30] => u [31] => v [32] => w [33] => x [34] => y [35] => z )
然後在0-35之間隨機生成一個數作為索引,其實就是在上面數組中隨機取出一個數,作為變量 $result 中的第一個字符。這個隨機索引隨後會被賦值成數組最後一個,它將不會參與下一輪的隨機選取。
<?php // 生成0123456789abcdefghijklmnopqrstuvwxyz中的一個字符 function getOptions() { $options = array(); $result = array(); for($i=48; $i<=57; $i++) { array_push($options,chr($i)); } for($i=65; $i<=90; $i++) { $j = 32; $small = $i + $j; array_push($options,chr($small)); } return $options; } /* $e = getOptions(); for($j=0; $j<150; $j++) { echo $e[$j]; } */ $len = 10; // 隨機生成數組索引,從而實現隨機數 for($j=0; $j<100; $j++) { $result = ""; $options = getOptions(); $lastIndex = 35; while (strlen($result)<$len) { // 從0到35中隨機取一個作為索引 $index = rand(0,$lastIndex); // 將隨機數賦給變量 $chr $chr = $options[$index]; // 隨機數作為 $result 的一部分 $result .= $chr; $lastIndex = $lastIndex-1; // 最後一個索引將不會參與下一次隨機抽獎 $options[$index] = $options[$lastIndex]; } echo $result."n"; } ?>