本章為大家介紹正規表達式中所有的表達符號(總結),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
一、校驗數字的表達式
數字:^[0-9]*$
n位的數字:^\d{n}$
至少n位的數字:^\d{n,}$
m-n位的數字:^\d{m,n}$
零和非零開頭的數字:^(0|[1-9][0-9]*)$
非零開頭的最多帶兩位小數的數字:^([1-9][0-9]*) (.[0-9]{1,2})?$
帶1-2位小數的正數或負數:^ (\-)?\d (\.\d{1,2})?$
正數、負數、和小數:^(\-|\ )?\d (\.\d )?$
有兩小數的正實數:^[0-9] (.[0-9]{2})?$
有1~3位小數的正實數:^[0-9] (.[0-9]{1,3})?$
非零的正整數:^[1-9]\d*$ 或^ ([1-9][0-9]*){1,3}$ 或^\ ?[1-9][0-9]*$
非零的負整數:^\ -[1-9][]0-9"*$ 或^-[1-9]\d*$
非負整數:^\d $ 或^[1-9]\d *|0$
非正整數:^-[1-9]\d*|0$ 或^((-\d )|(0 ))$
非負浮點數:^\d (\.\d )?$ 或^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\. 0 |0$
非正浮點數:^((-\d (\.\d )?)|(0 (\.0 )?))$ 或^(-([1- 9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0 |0$
正浮點數:^[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 ]*))$
負浮點數:^-([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]*)))$
浮點數:^(-?\d )(\. \d )?$ 或^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0 |0)$ p>
二、校驗字元的表達式
漢字:^[\u4e00-\u9fa5]{0,}$
英文和數字:^[A-Za-z0-9] $ 或^[A-Za-z0-9]{4,40}$
長度為3-20的所有字元:^.{ 3,20}$
由26個英文字母組成的字串:^[A-Za-z] $
由26個大寫英文字母組成的字串:^ [A-Z] $
由26個小寫英文字母組成的字串:^[a-z] $
由數字和26個英文字母組成的字串:^[A- Za-z0-9] $
由數字、26個英文字母或底線組成的字串:^\w $ 或^\w{3,20}$
中文、英文、數字包括底線:^[\u4E00-\u9FA5A-Za-z0-9_] $
中文、英文、數字但不包括底線等符號:^[\u4E00-\u9FA5A-Za -z0-9] $ 或^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$
可以輸入含有^%&',;=?$\"等字符:[^%&',;=?$\x22]
禁止輸入含有~的字元:[^~\x22]
三、特殊需求表達式
Email位址:^\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w ) *$
網域:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a -zA-Z0-9]{0,62}) /.?
InternetURL:[a-zA-z] ://[^\s]* 或^http://([\ w-] \.) [\w-] (/[\w-./?%&=]*)?$
手機號碼:^(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 }$
電話號碼("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX):^(\(\d {3,4}-)|\d{3.4}-)?\d{7,8}$
國內電話號碼(0511-4405222、021-87888822):d{3}-\d{8}|\d{4}-\d{7}
身分證字號(15位、18位數字):^\d{15}|\d{18}$
短身分證號碼(數字、字母x結尾):^([0-9]){7, 18}(x|X)?$ 或^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
帳號是否合法(字母開頭,允許5-16字節,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
密碼(以字母開頭,長度在6~18之間,只能包含字母、數字和底線):^[a-zA-Z]\w{5,17}$
強密碼(必須包含大小寫字母和數字的組合,不能使用特殊字符,長度在8-10之間):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]) .{8,10}$
日期格式:^\d{4}-\d{1,2}-\d{1,2}
一年的12個月(01~09和1~12):^(0?[1-9]|1[0-2])$
一個月的31天(01~09和1~31 ):^((0?[1-9])|((1|2)[0-9])|30|31)$
錢的輸入格式:
1.有四種錢的表示形式我們可以接受:"10000.00" 和"10,000.00", 和沒有"分" 的"10000" 和"10,000":^[1-9][0-9]*$
2、這表示任一不以0開頭的數字,但是,這也意味著一個字元"0"不通過,所以我們採用下面的形式:^(0|[1-9][0-9]*) $
3、一個0或一個不以0開頭的數字.我們還可以允許開頭有一個負號:^(0|-?[1-9][0-9]*)$
4.這表示一個0或一個可能為負的開頭不為0的數字.讓用戶以0開頭好了.把負號的也去掉,因為錢總不能是負的吧.下面我們要加的是說明可能的小數部分:^[0-9] (.[0-9] )?$
5.必須說明的是,小數點後面至少應該有1位數,所以"10."是不通過的,但是"10" 和"10.2" 是通過的:^[0-9] (.[0-9 ]{2})?$
6、 這樣我們規定小數點後面必須有兩位,如果你認為太苛刻了,可以這樣:^[0-9] (.[0-9]{1,2})?$
7. 這樣就允許用戶只寫一位小數.下面我們該考慮數字中的逗號了,我們可以這樣:^[0-9]{1,3}(,[0-9]{3})*( .[0-9]{1,2})?$
8、1到3個數字,後面跟著任意個逗號3個數字,逗號成為可選,而不是必須:^([0-9] |[0-9]{1,3}(,[0-9 ]{3})*)(.[0-9]{1,2})?$
備註:這就是最終結果了,別忘了" "可以用"*"替代如果你覺得空字符串也可以接受的話(奇怪,為什麼?)最後,別忘了在用函數時去掉去掉那個反斜杠,一般的錯誤都在這裡
xml檔:^([a-zA-Z] -?) [a-zA-Z0-9] \\.[x|X][m|M ][l|L]$
中文字元的正規表示式:[\u4e00-\u9fa5]
雙位元組字元:[^\x00-\xff] (包括漢字在內,可以用來計算字串的長度(一個雙字節字元長度計2,ASCII字元計1))
空白行的正規表示式:\n\s*\r (可以用來刪除空白行)
首尾空白字元的正規表示式:^\s*|\s*$或(^\s*)|(\s*$) (可以用來刪除行首行尾的空白字元(包含空格、製表符、換頁符號等等),非常有用的表達式)
騰訊QQ號:[1-9][0-9]{4,} (騰訊QQ號從10000開始)
中國郵遞區號:[1-9]\d{5}(?!\d) (中國郵遞區號為6位數)
IP位址:
IP位址:d \.\d \.\d \.\d (提取IP位址時有用)
IP位址:((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25 [0-5]|2[0-4]\\d|[01]?\\d?\\d))
以上就是最常用正規表示式你要的都在這裡了的內容,更多相關內容請關注PHP中文網(www.php.cn)!

防止會話固定攻擊的有效方法包括:1.在用戶登錄後重新生成會話ID;2.使用安全的會話ID生成算法;3.實施會話超時機制;4.使用HTTPS加密會話數據,這些措施能確保應用在面對會話固定攻擊時堅不可摧。

實現無會話身份驗證可以通過使用JSONWebTokens(JWT)來實現,這是一種基於令牌的認證系統,所有的必要信息都存儲在令牌中,無需服務器端會話存儲。 1)使用JWT生成和驗證令牌,2)確保使用HTTPS防止令牌被截獲,3)在客戶端安全存儲令牌,4)在服務器端驗證令牌以防篡改,5)實現令牌撤銷機制,如使用短期訪問令牌和長期刷新令牌。

PHP會話的安全風險主要包括會話劫持、會話固定、會話預測和會話中毒。 1.會話劫持可以通過使用HTTPS和保護cookie來防範。 2.會話固定可以通過在用戶登錄前重新生成會話ID來避免。 3.會話預測需要確保會話ID的隨機性和不可預測性。 4.會話中毒可以通過對會話數據進行驗證和過濾來預防。

銷毀PHP會話需要先啟動會話,然後清除數據並銷毀會話文件。 1.使用session_start()啟動會話。 2.用session_unset()清除會話數據。 3.最後用session_destroy()銷毀會話文件,確保數據安全和資源釋放。

如何改變PHP的默認會話保存路徑?可以通過以下步驟實現:在PHP腳本中使用session_save_path('/var/www/sessions');session_start();設置會話保存路徑。在php.ini文件中設置session.save_path="/var/www/sessions"來全局改變會話保存路徑。使用Memcached或Redis存儲會話數據,如ini_set('session.save_handler','memcached');ini_set(

tomodifyDataNaphPsession,startTheSessionWithSession_start(),然後使用$ _sessionToset,修改,orremovevariables.1)startThesession.2)setthesession.2)使用$ _session.3)setormodifysessessvariables.3)emovervariableswithunset()

在PHP會話中可以存儲數組。 1.啟動會話,使用session_start()。 2.創建數組並存儲在$_SESSION中。 3.通過$_SESSION檢索數組。 4.優化會話數據以提升性能。

PHP會話垃圾回收通過概率機制觸發,清理過期會話數據。 1)配置文件中設置觸發概率和會話生命週期;2)可使用cron任務優化高負載應用;3)需平衡垃圾回收頻率與性能,避免數據丟失。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載
最受歡迎的的開源編輯器

記事本++7.3.1
好用且免費的程式碼編輯器