


Kaedah ungkapan biasa PHP untuk mengesahkan kerumitan kata laluan
Jun 24, 2023 am 09:09 AMDengan peningkatan beransur-ansur kesedaran keselamatan rangkaian, banyak tapak web telah mula memerlukan pengguna untuk menggunakan kata laluan yang kompleks. Sebagai bahasa pengaturcaraan yang digunakan secara meluas, PHP secara semula jadi memerlukan kaedah yang sepadan untuk mengesahkan kerumitan kata laluan. Artikel ini akan memperkenalkan kaedah mengesahkan kerumitan kata laluan menggunakan ungkapan biasa PHP.
1. Keperluan kerumitan kata laluan
Sebelum mereka bentuk ungkapan biasa untuk pengesahan kerumitan kata laluan, kami perlu menentukan keperluan kerumitan kata laluan terlebih dahulu. Secara umumnya, keperluan kerumitan kata laluan termasuk aspek berikut:
- Panjang kata laluan: Panjang kata laluan tidak boleh kurang daripada nilai tertentu, biasanya 8-16 aksara.
- Jenis aksara: Kata laluan mesti mengandungi huruf besar dan kecil, nombor dan aksara khas (seperti !@#$%^&*()_+-=[]{}|;':",./ < >?)
- Kata laluan biasa tidak boleh digunakan: kata laluan tidak boleh mengandungi kata laluan biasa (seperti: 123456, admin, dll.)
2. Ungkapan biasa PHP. Kaedah untuk mengesahkan kerumitan kata laluan menggunakan ungkapan biasa
- Mengesahkan panjang kata laluan
Adalah sangat mudah untuk menggunakan ungkapan biasa untuk mengesahkan panjang kata laluan, hanya gunakan ".{8,16 }" iaitu Ya. Antaranya, titik bermaksud ia boleh memadankan mana-mana aksara, 8 dalam kurungan kerinting bermakna ia mesti sepadan dengan sekurang-kurangnya 8 aksara dan 16 bermakna ia boleh memadankan sehingga 16 aksara. Contoh kod:
if(preg_match('/.{8,16}/',$password)){ echo '密码长度符合要求'; }else{ echo '密码长度不符合要求'; }
<. 🎜>Pengesahan jenis aksara kata laluan
- Pengesahan jenis aksara kata laluan adalah lebih rumit dan anda perlu menggunakan "[]" dalam ungkapan biasa untuk mewakili padanan set aksara. Kaedah pelaksanaan khusus adalah seperti berikut:
//验证是否包含数字 if(preg_match('/[0-9]+/',$password)){ $score++; } //验证是否包含小写字母 if(preg_match('/[a-z]+/',$password)){ $score++; } //验证是否包含大写字母 if(preg_match('/[A-Z]+/',$password)){ $score++; } //验证是否包含特殊字符 if(preg_match('/[!@#$%^&*()_+-=[]{}|;:'",./<>?]+/',$password)){ $score++; } if($score>=3){ echo '密码复杂度符合要求'; }else{ echo '密码复杂度不符合要求'; }
Sahkan sama ada kata laluan biasa disertakan
- Sahkan sama ada kata laluan biasa. disertakan juga agak mudah, hanya gunakan "|" dalam ungkapan biasa untuk mewakili hubungan "atau" Itu sahaja kaedah pelaksanaan khusus adalah seperti berikut:
//常用密码列表 $commonPasswords = array('123456','admin','password','qwerty','12345678'); //验证密码是否为常用密码 if(preg_match('/('.implode('|', $commonPasswords).')/i', $password)){ echo '密码为常用密码'; }else{ echo '密码不为常用密码'; }
Kaedah utama pengesahan ungkapan biasa PHP kerumitan kata laluan termasuk Sahkan panjang kata laluan, jenis aksara kata laluan dan sama ada ia mengandungi kata laluan yang biasa digunakan Pengaturcara boleh mereka bentuk ungkapan biasa pengesahan kerumitan kata laluan mereka sendiri mengikut keperluan khusus untuk meningkatkan keselamatan kata laluan dan menjadikannya lebih mudah untuk pengguna
Atas ialah kandungan terperinci Kaedah ungkapan biasa PHP untuk mengesahkan kerumitan kata laluan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP
