搜尋
首頁後端開發php教程最全的常用正規表示式大全-包括校驗數字、字元、一些特殊的需求等

一、校驗數字的表達式

1 數字:^[0-9]*$ 

2 n位的數字:^d{n}$

3 至少n位的數字:^d{n, }$ 

4 m-n位的數字:^d{m,n}$ 

5 零與非零開頭的數字:^(0|[1-9][0-9]*)$ 

6 非零開頭的最多帶兩位小數的數字:^([1-9][0-9]*)+(.[0-9]{1,2})?$ 

7 帶1-2位小數的正數或負數:^(-)?d+(.d{1,2})?$ 

8 正數、負數、和小數:^(-|+)?d+(.d+)?$ 

9 有兩位小數的正實數:^[0-9]+(.[0-9]{2})?$

10 有1~3位小數的正實數:^[0-9]+( .[0-9]{1,3})?$

11 非零的正整數:^[1-9]d*$ 或^([1-9][0-9]*){1, 3}$ 或^+?[1-9][0-9]*$

12 非零的負整數:^-[1-9][]0-9"*$ 或^-[1-9 ]d*$

13 非負整數:^d+$ 或^[1-9]d*|0$

14 非正整數:^-[1-9]d*|0$ 或^((- d+)|(0+))$

15 非負浮點數:^d+(.d+)?$ 或^[1-9]d*.d*|0.d*[1-9]d*| 0?.0+|0$

16 非正浮點數:^((-d+(.d+)?)|(0+(.0+)?))$ 或^(-([1-9] d*.d*|0.d*[1-9]d*))|0?.0+|0$

17 正浮點數:^[1-9]d*.d*|0.d *[1-9]d*$ 或^(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9 ][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*))$

18 負浮點數:^-([1- 9]d*.d*|0.d*[1-9]d*)$ 或^(-(([0-9]+.[0-9]*[1-9][0-9] *)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*)) )$

19 浮點數:^(-?d+)(.d+)?$ 或^-?([1-9]d*.d*|0.d*[1-9]d*|0? .0+|0)$

二、校驗字符的表達式

1 漢字:^[u4e00-u9fa5]{0,}$ 

2 英文和數字:^[A-Za-z0-9] +$ 或^[A-Za-z0-9]{4,40}$ 

3 長度為3-20的所有字符:^.{3,20}$ 

4 由26個英文字母組成的字符字串:^[A-Za-z]+$ 

5 由26個大寫英文字母組成的字串:^[A-Z]+$ 

6 由26個小寫英文字母組成的字串:^[a-z] +$ 

7 由數字和26個英文字母組成的字串:^[A-Za-z0-9]+$ 

8 由數字、26個英文字母或底線組成的字串:^w+$ 或^w{3,20}$ 

9 中文、英文、數字包括底線:^[u4E00-u9FA5A-Za-z0-9_]+$

10 中文、英文、數字但不包括底線等符號:^[ u4E00-u9FA5A-Za-z0-9]+$ 或^[u4E00-u9FA5A-Za-z0-9]{2,20}$

11 可以輸入含有^%&',;=?$"等字元: [^%&',;=?$x22]+

12 禁止輸入含有~的字元:[^~x22]+

三、特殊需求表達式

1 Email位址:^w+([-+. ]w+)*@w+([-.]w+)*.w+([-.]w+)*$ 

2 網域:[a-zA-Z0-9][-a-zA-Z0-9]{ 0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.? 

3 InternetURL:[a-zA-z]+: //[^s]* 或^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$ 

4 手機號碼:^ (13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6| 7|8|9])d{8}$ 

5 電話號碼("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX): ^((d{3,4}-)|d{3.4}-)?d{7,8}$  

6 國內電話號碼(0511-4405222、021-87888822):d{3}-d{8 }|d{4}-d{7} 

7 身分證號(15位、18位數字):^d{15}|d{18}$ 

8 短身分證號碼(數字、字母x結尾):^([0-9]){7,18}(x|X)?$ 或^d{8,18}|[0-9x]{8,18}|[0-9X]{8, 18}?$ 

9 帳號是否合法(字母開頭,允許5-16字節,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$

10 密碼(以字母開頭,長度在6~18之間,只能包含字母、數字和底線):^[a-zA-Z]w{5,17}$

11 強密碼(必須包含大小寫字母和數字的組合,不能使用特殊字符,長度在8-10之間):^(?=.*d)(?=.*[a-z])(?=.*[A-Z]).{ 8,10}$

12 日期格式:^d{4}-d{1,2}-d{1,2}

13 一年的12個月(01~09和1~12):^ (0?[1-9]|1[0-2])$

14 一個月的31天(01~09和1~31):^((0?[1-9])|((1 |2)[0-9])|30|31)$

15 錢的輸入格式:

16 1.有四種錢的表示形式我們可以接受:"10000.00" 和"10,000.00", 和沒有"分" 的"10000" 和"10,000":^[1-9][0-9]*$

17 2.這表示任意一個不以0開頭的數字,但是,這也意味著一個字元"0 "不通過,所以我們採用下面的形式:^(0|[1-9][0-9]*)$

18 3.一個0或一個不以0開頭的數字.我們還可以允許開頭有一個負號:^(0|-?[1-9][0-9]*)$

19 4.這表示一個0或一個可能為負的開頭不為0的數字.讓使用者以0開頭好了.把負號的也去掉,因為錢總不能是負的吧.下面我們要加的是說明可能的小數部分:^[0-9]+(.[0-9]+)?$

20 5.必須說明的是,小數點後面至少應該有1位數,所以"10."是不通過的,但是"10" 和"10.2" 是通過的:^[0-9]+(.[ 0-9]{2})?$

21 6.這樣我們規定小數點後面必須有兩位,如果你認為太苛刻了,可以這樣:^[0-9]+(.[0-9]{ 1,2})?$

22 7.這樣就允許使用者只寫一位小數.下面我們該考慮數字中的逗號了,我們可以這樣:^[0-9]{1,3}(,[0-9]{3}) *(.[0-9]{1,2})?$

23 8.1到3個數字,後面跟著任意個逗號+3個數字,逗號成為可選,而不是必須:^([0-9 ]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$

24 備註:這就是最終結果了,別忘了"+"可以用"*"替代如果你覺得空字串也可以接受的話(奇怪,為什麼?)最後,別忘了在用函數時去掉去掉那個反斜線,一般的錯誤都這裡

25 xml檔:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\.[x|X][m|M][l|L]$

26 中文字元的正規表示式:[u4e00-u9fa5]

27 雙位元組字元:[^x00-xff] (包括漢字在內,可以用來計算字串的長度(一個雙位元組字元長度計2,ASCII字元計1))

28 空白行的正規表示式:ns*r (可以用來刪除空白行)

29 HTML標記的正規表示式:] *>.*?1>|<.> (網上流傳的版本太糟糕,上面這個也僅僅能部分,對於復雜的嵌套標記依舊無能為力)

30 首尾空白字符的正則表達式:^s*|s*$或(^s*)|(s*$) (可以用來刪除行首行尾的空白字元(包括空格、製表符、換頁符等等),非常有用的表達式)

31 騰訊QQ號:[1-9][0-9]{4,} (騰訊QQ號從10000開始)

32 中國郵遞區號:[1-9]d{5}(? !d) (中國郵遞區號為6位數字) 33 IP位址:d+.d+.d+.d+ (提取IP位址時有用) 34 IP位址:((?:(?:25[0-5]|2[ 0-4]\d|[01]?\d?\d)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d?\ d)) 

更多最完整的常用正規表示式大全-包括校驗數字、字元、一些特殊的需求等相關文章請關注PHP中文網!


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
可以在PHP會話中存儲哪些數據?可以在PHP會話中存儲哪些數據?May 02, 2025 am 12:17 AM

phpsessionscanStorestrings,數字,數組和原始物。

您如何開始PHP會話?您如何開始PHP會話?May 02, 2025 am 12:16 AM

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考慮使用AttActAcks.s.s.4)

什麼是會話再生,如何提高安全性?什麼是會話再生,如何提高安全性?May 02, 2025 am 12:15 AM

會話再生是指在用戶進行敏感操作時生成新會話ID並使舊ID失效,以防會話固定攻擊。實現步驟包括:1.檢測敏感操作,2.生成新會話ID,3.銷毀舊會話ID,4.更新用戶端會話信息。

使用PHP會話時有哪些性能考慮?使用PHP會話時有哪些性能考慮?May 02, 2025 am 12:11 AM

PHP会话对应用性能有显著影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

PHP會話與Cookie有何不同?PHP會話與Cookie有何不同?May 02, 2025 am 12:03 AM

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

PHP如何識別用戶的會話?PHP如何識別用戶的會話?May 01, 2025 am 12:23 AM

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

確保PHP會議的一些最佳實踐是什麼?確保PHP會議的一些最佳實踐是什麼?May 01, 2025 am 12:22 AM

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

PHP會話文件默認存儲在哪裡?PHP會話文件默認存儲在哪裡?May 01, 2025 am 12:15 AM

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。