如何使用PHP生成隨機(jī)碼?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
成都創(chuàng)新互聯(lián)公司專注于邛崍企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站建設(shè),商城網(wǎng)站建設(shè)。邛崍網(wǎng)站建設(shè)公司,為邛崍等地區(qū)提供建站服務(wù)。全流程按需求定制開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)php,一個(gè)嵌套的縮寫名稱,是英文超級(jí)文本預(yù)處理語言(PHP:Hypertext Preprocessor)的縮寫。PHP 是一種 HTML 內(nèi)嵌式的語言,PHP與微軟的ASP頗有幾分相似,都是一種在服務(wù)器端執(zhí)行的嵌入HTML文檔的腳本語言,語言的風(fēng)格有類似于C語言,現(xiàn)在被很多的網(wǎng)站編程人員廣泛的運(yùn)用。
解題思路
(1) . 第一思路
都是印象中匹配ASCII碼進(jìn)行隨機(jī)讀取的實(shí)現(xiàn)方法,此處可提供一個(gè)方法作為參考:
function get_rand_ascii($pw_length = 5){ $randpwd = ''; for ($i = 0; $i < $pw_length; $i++) { $randpwd .= chr(mt_rand(33, 99)); } return $randpwd; }
(2) . 第二思路
1.定義隨機(jī)數(shù)組,內(nèi)含能夠使用的所有字符
function getRandomString($length=5) { //可任意添加需要的字符 $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" ); $charsLen = count ( $chars ) - 1; shuffle ( $chars ); // 將數(shù)組打亂 $output = ""; for($i = 0; $i < $length; $i ++) { $output .= $chars [mt_rand ( 0, $charsLen )]; } return $output; }
提示:此類的代碼,建議去除可能引起歧義的字符,如:1、I、l、0、o、O、9、q.
缺點(diǎn):5個(gè)字符沒有重復(fù)
2.比較上述 1 中的數(shù)組形式,設(shè)計(jì)字符串形式參考如下:
function get_pass( $length = 8 ) { // 密碼字符集,可任意添加你需要的字符 $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*()-_ []{}<>~`+=,.;:/?|'; $password = ''; for ( $i = 0; $i < $length; $i++ ) { // 這里提供兩種字符獲取方式 // 第一種是使用 substr 截取$chars中的任意一位字符; // 第二種是取字符數(shù)組 $chars 的任意元素 // $password .= substr($chars, mt_rand(0, strlen($chars) - 1), 1); $password .= $chars[ mt_rand(0, strlen($chars) - 1) ]; } return $password; }
(3) . 第三思路
發(fā)現(xiàn)的新思路,可使用加密算法進(jìn)行獲取
public function getRand(){ $rand = rand(10000,100000); $str = substr(base64_encode($rand), 0, 5); return $str; }
提示:md5()
函數(shù)只有數(shù)字和小寫的字母
發(fā)現(xiàn):base64_encode()
可以滿足要求
拓展延伸
針對(duì)于PHP設(shè)計(jì),一般的隨機(jī)碼可用于驗(yàn)證碼、分享碼的生成,著重注意位數(shù)的限制,必要情況下,保證該隨機(jī)碼的性.
password_hash
的使用(PHP>5.5)
可用于用戶的密碼加密存儲(chǔ),不過有一點(diǎn)需注意:如果數(shù)據(jù)庫遷移,對(duì)于java或.net語言將難以適用.
$password = 'password1232456';//前端 獲取的原始密碼 //數(shù)據(jù)庫存放的 使用BCRYPT算法加密的密碼 //此處僅為測(cè)試,實(shí)際應(yīng)用時(shí)應(yīng)從數(shù)據(jù)表中查詢獲得 //$db_pass = '$2y$10$2vJJC.rb/swAUnTfc9B94.l/ix75kiZHvOZFpu0Dd8uzp07YWlj4q'; $db_pass = password_hash($password, PASSWORD_BCRYPT); if (password_verify($password , $db_pass)){ echo "密碼匹配"; }else{ echo "密碼錯(cuò)誤"; }
看完上述內(nèi)容,你們掌握如何使用PHP生成隨機(jī)碼的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!