PHP生成隨機密碼的4種方法及效能對比

2021-07-23 09:46:49 字數 2676 閱讀 5571

1、方法一:

① 在 33 – 126 中生成乙個隨機整數,如 35;

② 將 35 轉換成對應的ascii碼字元,如 35 對應 #;

③ 重複以上 1、2 步驟 n 次,連線成 n 位的密碼。

該演算法主要用到了兩個函式,mt_rand ( int $min , int $max )函式用於生成隨機整數,其中 $min – $max 為 ascii 碼的範圍,這裡取 33 -126 ,可以根據需要調整範圍,如ascii碼表中 97 – 122 位對應 a – z 的英文本母,具體可參考 ascii碼表; chr ( int $ascii )函式用於將對應整數 $ascii 轉換成對應的字元。

/**

* 2016-10-04

* zhihua_w

*/<?php

function create_password($pw_length = 8)

return $randpwd;

}// 呼叫該函式,傳遞長度引數$pw_length = 6

echo create_password(6);

?>

2、方法二:

① 預置乙個的字串 $chars ,包括 a – z,a – z,0 – 9,以及一些特殊字元;

② 在 $chars 字串中隨機取乙個字元;

③ 重複第二步 n 次,可得長度為 n 的密碼。

/**

* 2016-10-04

* zhihua_w

*/<?php

function generate_password( $length = 8 )

<>~`+=,.;:/?|';

$password = '';

for ( $i = 0; $i < $length; $i++ )

return $password;

}?>

3、方法三:

① 預置乙個的字元陣列 $chars ,包括 a – z,a – z,0 – 9,以及一些特殊字元;

② 通過array_rand()從陣列 $chars 中隨機選出 $length 個元素;

③ 根據已獲取的鍵名陣列 $keys,從陣列 $chars 取出字元拼接字串。該方法的缺點是相同的字元不會重複取。

/**

* 2016-10-04

* zhihua_w

*/<?php

function make_password( $length = 8 )

', '<', '>', '~', '`', '+', '=', ',',

'.', ';', ':', '/', '?', '|');

// 在 $chars 中隨機取 $length 個陣列元素鍵名

$keys = array_rand($chars, $length);

$password = '';

for($i = 0; $i < $length; $i++)

return $password;

}?>

4、方法四:

① time() 獲取當前的時間戳;

② 將第一步獲取的時間戳進行 md5() 加密;

③ 將第二步加密的結果,擷取 n 位即得想要的密碼

/**

* 2016-10-04

* zhihua_w

*/<?php

function get_password( $length = 8 )

?>

5、時間效率對比

我們使用以下php**,計算上面的 4 個隨機密碼生成函式生成 6 位密碼的執行時間,進而對他們的時間效率進行乙個簡單的對比。

/**

* 2016-10-04

* zhihua_w

*/<?php

function getmicrotime()

// 記錄開始時間

$time_start = getmicrotime();

// 這裡放要執行的php**,如:

// echo create_password(6);

// 記錄結束時間

$time_end = getmicrotime();

$time = $time_end - $time_start;

// 輸出執行總時間

echo "執行時間 $time seconds";

?>

大家可以通過此種方式對時間效率進行對比,通過執行所需的時間可以看出方法一和方法二的執行時間都差不多,方法四執行時間最短,而方法三的執行時間稍微長點。

PHP生成隨機密碼的4種方法及效能對

1 在 33 126 中生成乙個隨機整數,如 35,2 將 35 轉換成對應的ascii碼字元,如 35 對應 3 重複以上 1 2 步驟 n 次,連線成 n 位的密碼 該演算法主要用到了兩個函式,mt rand int min int max 函式用於生成隨機整數,其中 min max 為 asc...

PHP生成隨機密碼4種方法及效能對比

方法一 1 在 33 126 中生成乙個隨機整數,如 35,2 將 35 轉換成對應的ascii碼字元,如 35 對應 3 重複以上 1 2 步驟 n 次,連線成 n 位的密碼 該演算法主要用到了兩個函式,mt rand int min int max 函式用於生成隨機整數,其中 min max 為...

php生成隨機密碼的幾種方法

方法一 1 在 33 126 中生成乙個隨機整數,如 35,2 將 35 轉換成對應的ascii碼字元,如 35 對應 3 重複以上 1 2 步驟 n 次,連線成 n 位的密碼 該演算法主要用到了兩個函式,mt rand int min int max 函式用於生成隨機整數,其中 min max 為...