PHP正規表示式實戰:匹配使用者名

王林
發布: 2023-06-23 09:14:01
原創
1416 人瀏覽過

在web開發中,很多時候需要對資料進行格式限製或格式檢查,PHP正規表示式是進行這類操作的強大工具之一。在本文中,我們將透過實戰進行解說,教導大家如何使用PHP正規表示式進行配對使用者名稱。

1.使用者名稱要求

首先,我們需要明確使用者名稱的要求,以便我們知道需要使用什麼樣的正規表示式來進行匹配。通常情況下,使用者名稱要求如下:

  • 由字母、數字或底線組成;
  • 長度在6到20個字元之間;
  • 不以數字開頭;
  • 不允許使用特殊字元。

根據這些要求,我們就可以開始寫正規表示式了。

2.寫正規表示式

我們先來分析每個要求需要使用到的正規表示式:

  • 由字母、數字或底線組成。

這個要求很容易滿足,只需要使用字元集[0-9a-zA-Z_]即可。

  • 長度在6到20個字元之間。

這個要求需要使用量詞,也就是{6,20}表示符合6到20個字元。我們需要將字元集加入字元集中,最終得到:[0-9a-zA-Z_]{6,20}。

  • 不以數字開頭。

這個要求需要使用零寬斷言,即在字元集前加上(?=D)表示匹配必須以非數字開頭。最終得到:(?=D)[0-9a-zA-Z_]{6,20}。

  • 不允許使用特殊字元。

這個要求需要排除特殊字符,我們可以使用排除字符集1。由於需要排除的字元集比較多,我們可以使用Unicode編碼範圍來表示需要排除的字元集:[u4e00-u9fa5uFE30-uFFA0u3000-u303F]|[s~!@#$%^&*()_ ={}[]|\;:'",.<>/?·!¥…()—《》【】、;':「,。 、? ]。最終得到:(?=D)[0-9a-zA-Z_]{6,20}(?![u4e00-u9fa5uFE30-uFFA0u3000-u303F]|[s#~!@#$%^&*( )_ ={}[]|\;:'",.<>/?·!¥…()—《》【】、;':“,。、?])。

3.使用正規表示式進行匹配

現在我們已經編寫好了正規表示式,接下來就可以使用PHP的preg_match函數進行匹配了。下面是一個範例程式碼:

function matchUsername($username) {
    $pattern = '/^(?=D)[0-9a-zA-Z_]{6,20}(?![u4e00-u9fa5uFE30-uFFA0u3000-u303F]|[s`~!@#$%^&*()_+={}[]|\;:'",.<>/?·!¥……()—《》【】、;‘:“,。、?])$/';
    if(preg_match($pattern, $username)) {
        return true;
    }
    return false;
}

$username1 = 'abcde';
$username2 = 'abcd@e';
$username3 = '1abcde';
$username4 = '123456789abcdefghi';
$username5 = '张三';
$username6 = 'abcdef张三';

var_dump(matchUsername($username1)); // true
var_dump(matchUsername($username2)); // false
var_dump(matchUsername($username3)); // false
var_dump(matchUsername($username4)); // false
var_dump(matchUsername($username5)); // false
var_dump(matchUsername($username6)); // false
登入後複製

在程式碼中,我們定義了一個matchUsername函數來進行匹配,並且分別用測試案例來進行驗證。運行程式碼後,可以看到除了$username1外,其餘的測試案例都沒有通過匹配。

至此,我們已經透過實戰講解如何使用PHP正規表示式進行比對使用者名,希望對初學者有所幫助。


  1. 特殊字元集
#

以上是PHP正規表示式實戰:匹配使用者名的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板