Rumah > pembangunan bahagian belakang > tutorial php > Kaedah ungkapan biasa PHP untuk mengesahkan kerumitan kata laluan

Kaedah ungkapan biasa PHP untuk mengesahkan kerumitan kata laluan

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2023-06-24 11:20:02
asal
1835 orang telah melayarinya

Dengan 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:

  1. Panjang kata laluan: Panjang kata laluan tidak boleh kurang daripada nilai tertentu, biasanya 8-16 aksara.
  2. Jenis aksara: Kata laluan mesti mengandungi huruf besar dan kecil, nombor dan aksara khas (seperti !@#$%^&*()_+-=[]{}|;':",./ < >?)
  3. 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

  1. 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 '密码长度不符合要求';
}
Salin selepas log masuk

<. 🎜>Pengesahan jenis aksara kata laluan

  1. 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:
  2. //验证是否包含数字
    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 '密码复杂度不符合要求';
    }
    Salin selepas log masuk
Dalam kod di atas, kami menggunakan beberapa ungkapan biasa untuk mengesahkan sama ada kata laluan memenuhi keperluan, antaranya, kurungan segi empat sama "[]" menunjukkan a set aksara yang sepadan, dan tanda tambah "+" menunjukkan bahawa set aksara mesti muncul sekurang-kurangnya sekali

Sahkan sama ada kata laluan biasa disertakan

  1. 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:
  2. //常用密码列表
    $commonPasswords = array('123456','admin','password','qwerty','12345678');
    
    //验证密码是否为常用密码
    if(preg_match('/('.implode('|', $commonPasswords).')/i', $password)){
      echo '密码为常用密码';
    }else{
      echo '密码不为常用密码';
    }
    Salin selepas log masuk
    Dalam kod di atas, kami menggunakan. fungsi implode untuk menyambungkan elemen dalam senarai kata laluan biasa dengan garis menegak untuk membentuk ungkapan biasa "()" bermaksud memadankan rentetan, dan "i" bermaksud mengabaikan huruf kecil apabila memadankan

    3 >

    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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Isu terkini
pemerolehan data php?
daripada 1970-01-01 08:00:00
0
0
0
sambungan PHP intl
daripada 1970-01-01 08:00:00
0
0
0
Bagaimana untuk belajar php dengan baik
daripada 1970-01-01 08:00:00
0
0
0
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan