PHP下ereg實(shí)現(xiàn)匹配ip的正則
更新時(shí)間:2007年11月08日 22:04:54 作者:
我們先看個(gè)代碼片段:
$ip = "1.1.1.255".chr(0)."haha";
if(ereg("^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$",$ip)) {
echo $ip;
} else {
echo "unknown";
}
這個(gè)ereg正則限制了$ip的數(shù)據(jù)為xxx.xxx.xxx.xxx這樣的形式,表面上看上面的代碼應(yīng)該輸出"unknown",而實(shí)際卻輸出了"1.1.1.255haha",因?yàn)閑reg函數(shù)存在NULL截?cái)嗦┒?,?dǎo)致了正則過濾被繞過。4 \2 n+ Y6 |; Z7 O
6 e& b6 C5 F- W- F$ z我們在利用時(shí)必須要引入\x00(%00),而在GPC為ON的情況下%00會(huì)被轉(zhuǎn)義導(dǎo)致無法利用。但是如果被ereg()處理的是$ _SERVER(在PHP5下可以繞過GPC)或是被urldecode這樣的函數(shù)處理導(dǎo)致GPC被繞過的數(shù)據(jù)呢?比如有些程序就用上面的方法驗(yàn)證$ _SERVER提交上來的IP,那么我們就可以利用NULL截?cái)嗬@過正則過濾來構(gòu)造我們需要的數(shù)據(jù)了:)
復(fù)制代碼 代碼如下:
$ip = "1.1.1.255".chr(0)."haha";
if(ereg("^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$",$ip)) {
echo $ip;
} else {
echo "unknown";
}
6 e& b6 C5 F- W- F$ z我們在利用時(shí)必須要引入\x00(%00),而在GPC為ON的情況下%00會(huì)被轉(zhuǎn)義導(dǎo)致無法利用。但是如果被ereg()處理的是$ _SERVER(在PHP5下可以繞過GPC)或是被urldecode這樣的函數(shù)處理導(dǎo)致GPC被繞過的數(shù)據(jù)呢?比如有些程序就用上面的方法驗(yàn)證$ _SERVER提交上來的IP,那么我們就可以利用NULL截?cái)嗬@過正則過濾來構(gòu)造我們需要的數(shù)據(jù)了:)
您可能感興趣的文章:
- php中有關(guān)字符串的4個(gè)函數(shù)substr、strrchr、strstr、ereg介紹和使用例子
- ThinkPHP實(shí)現(xiàn)帶驗(yàn)證碼的文件上傳功能實(shí)例
- PHP 基于文件頭的文件類型驗(yàn)證類函數(shù)
- 一個(gè)經(jīng)典的PHP驗(yàn)證碼類分享
- php驗(yàn)證session無效的解決方法
- php實(shí)現(xiàn)的click captcha點(diǎn)擊驗(yàn)證碼類實(shí)例
- php實(shí)現(xiàn)的Captcha驗(yàn)證碼類實(shí)例
- PHP使用GIFEncoder類生成的GIF動(dòng)態(tài)圖片驗(yàn)證碼
- php使用ereg驗(yàn)證文件上傳的方法
相關(guān)文章
RegExp 隨筆 JavaScript RegExp 對(duì)象
這篇文章主要介紹了RegExp 隨筆 JavaScript RegExp 對(duì)象,需要的朋友可以參考下2016-10-10
javascript 正則表達(dá)式(二) 使用技巧說明
javascript 正則表達(dá)式(二) 使用技巧說明2010-05-05

