目錄
基礎要求:長度與字符種類
進階限制:避免連續或重複字符
避免常見弱密碼
首頁 後端開發 php教程 PHP正則密碼強度

PHP正則密碼強度

Jul 03, 2025 am 10:33 AM

判斷密碼強度需結合正則與邏輯處理,基礎要求包括:1.長度不少於8位;2.至少含小寫字母、大寫字母、數字;3.可加入特殊字符限制;進階方面需避免連續重複字符及遞增/遞減序列,這需PHP函數檢測;同時應引入黑名單過濾常見弱密碼如password、123456;最終建議結合zxcvbn庫提升評估精度。

php regex for password strength

判斷密碼強度是開發中常見的需求,PHP 中通常用正則表達式來實現。但光寫個regex 不夠,得理解它背後的邏輯和應用場景。

php regex for password strength

基礎要求:長度與字符種類

最簡單的密碼強度規則,通常包括最小長度(比如8位)和至少包含幾類字符(大小寫字母、數字、特殊符號)。

php regex for password strength
 $pattern = '/^(?=.*[az])(?=.*[AZ])(?=.*\d).{8,}$/';

這個正則的意思是:

  • (?=.*[az])至少有一個小寫字母
  • (?=.*[AZ])至少有一個大寫字母
  • (?=.*\d)至少有一個數字
  • .{8,}總長度不少於8位

如果想再加一個特殊字符的要求,可以加上:

php regex for password strength
 (?=.*[!@#$%^&*])

進階限制:避免連續或重複字符

有些系統會禁止用戶設置像123456aaaabbbb這種有明顯規律的密碼。這時候正則就不太夠用了,需要結合PHP 的邏輯判斷。

例如檢測是否有三個以上連續相同字符:

 function hasConsecutiveChars($password) {
    return preg_match('/(\w)\1{2,}/', $password);
}

或者檢查是否有簡單遞增/遞減序列(如abc321 ),這種就需要遍歷字符串逐個比較,不能只靠正則。

避免常見弱密碼

即使滿足了字符類型和長度要求,用戶也可能輸入Password123Qwerty123這類常見弱密碼。這時候建議引入黑名單機制:

 $weakPasswords = ['password', '123456', 'qwerty'];
if (in_array(strtolower($password), $weakPasswords)) {
    // 密碼太弱,拒絕使用}

更高級的做法是集成zxcvbn這類庫來做真實強度評估,但那是另一個話題了。


基本上就這些。用正則控制基礎結構,配合PHP 邏輯處理複雜情況,再加上黑名單過濾,基本能滿足大多數項目的需求。不復雜但容易忽略細節,比如邊界條件或編碼問題,記得測試時多覆蓋幾種輸入形式。

以上是PHP正則密碼強度的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

在Linux上配置PHP開發環境的步驟 在Linux上配置PHP開發環境的步驟 Jun 30, 2025 am 01:57 AM

TosetupaPHPdevelopmentenvironmentonLinux,installPHPandrequiredextensions,setupawebserverlikeApacheorNginx,testwithaPHPfile,andoptionallyinstallMySQLandComposer.1.InstallPHPandextensionsviapackagemanager(e.g.,sudoaptinstallphpphp-mysqlphp-curlphp-mbst

如何將兩個PHP陣列組合獨特的值? 如何將兩個PHP陣列組合獨特的值? Jul 02, 2025 pm 05:18 PM

要合併兩個PHP數組並保留唯一值,有兩種主要方法。 1.對於索引數組或僅需值去重的情況,使用array_merge和array_unique組合:先用array_merge($array1,$array2)合併數組,再用array_unique()去重,最終得到包含所有唯一值的新數組;2.對於關聯數組且希望保留第一個數組中的鍵值對時,使用 運算符:$result=$array1 $array2,這將確保第一個數組中的鍵不會被第二個數組覆蓋。這兩種方法分別適用於不同場景,根據是否需要保留鍵名或只關注

PHP正則密碼強度 PHP正則密碼強度 Jul 03, 2025 am 10:33 AM

判斷密碼強度需結合正則與邏輯處理,基礎要求包括:1.長度不少於8位;2.至少含小寫字母、大寫字母、數字;3.可加入特殊字符限制;進階方面需避免連續重複字符及遞增/遞減序列,這需PHP函數檢測;同時應引入黑名單過濾常見弱密碼如password、123456;最終建議結合zxcvbn庫提升評估精度。

如何在PHP中牢固地處理文件上傳? 如何在PHP中牢固地處理文件上傳? Jul 08, 2025 am 02:37 AM

要安全處理PHP文件上傳需驗證來源與類型、控製文件名與路徑、設置服務器限制並二次處理媒體文件。 1.驗證上傳來源通過token防止CSRF並通過finfo_file檢測真實MIME類型使用白名單控制;2.重命名文件為隨機字符串並根據檢測類型決定擴展名存儲至非Web目錄;3.PHP配置限制上傳大小及臨時目錄Nginx/Apache禁止訪問上傳目錄;4.GD庫重新保存圖片清除潛在惡意數據。

在PHP中評論代碼 在PHP中評論代碼 Jul 18, 2025 am 04:57 AM

PHP註釋代碼常用方法有三種:1.單行註釋用//或#屏蔽一行代碼,推薦使用//;2.多行註釋用/.../包裹代碼塊,不可嵌套但可跨行;3.組合技巧註釋如用/if(){}/控制邏輯塊,或配合編輯器快捷鍵提升效率,使用時需注意閉合符號和避免嵌套。

撰寫PHP評論的提示 撰寫PHP評論的提示 Jul 18, 2025 am 04:51 AM

寫好PHP註釋的關鍵在於明確目的與規範,註釋應解釋“為什麼”而非“做了什麼”,避免冗餘或過於簡單。 1.使用統一格式,如docblock(/*/)用於類、方法說明,提升可讀性與工具兼容性;2.強調邏輯背後的原因,如說明為何需手動輸出JS跳轉;3.在復雜代碼前添加總覽性說明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標記待辦事項與問題,便於後續追踪與協作。好的註釋能降低溝通成本,提升代碼維護效率。

PHP變量範圍解釋了 PHP變量範圍解釋了 Jul 17, 2025 am 04:16 AM

PHP變量作用域常見問題及解決方法包括:1.函數內部無法訪問全局變量,需使用global關鍵字或參數傳入;2.靜態變量用static聲明,只初始化一次並在多次調用間保持值;3.超全局變量如$_GET、$_POST可在任何作用域直接使用,但需注意安全過濾;4.匿名函數需通過use關鍵字引入父作用域變量,修改外部變量則需傳遞引用。掌握這些規則有助於避免錯誤並提升代碼穩定性。

發電機如何在PHP中工作? 發電機如何在PHP中工作? Jul 11, 2025 am 03:12 AM

AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

See all articles