亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 深入研究PHP中的preg_replace和代碼執行

深入研究PHP中的preg_replace和代碼執行

熱門標簽:企業400電話辦理多少費用 萍鄉商鋪地圖標注 太原400電話申請流程 代理打電話機器人 桂陽公司如何做地圖標注 宿州正規外呼系統軟件 神龍斗士電話機器人 合肥企業外呼系統線路 電信外呼系統多少錢一個月

前言

本文將深入研究 preg_replace /e 模式下的代碼執行問題,其中包括 preg_replace 函數的執行過程分析、正則表達式分析、漏洞觸發分析,當中的坑非常多,相信看完本文,你一定會有所收獲。下面是 七月火 和 l1nk3r 的分析結果。

案例

下面先看一個案例,思考如何利用此處的 preg_replace /e 模式,執行代碼(可以先不看下文分析,自己思考出 payload 試試)。

這個案例實際上很簡單,就是 preg_replace 使用了 /e 模式,導致可以代碼執行,而且該函數的第一個和第三個參數都是我們可以控制的。我們都知道, preg_replace 函數在匹配到符號正則的字符串時,會將替換字符串(也就是上圖 preg_replace 函數的第二個參數)當做代碼來執行,然而這里的第二個參數卻固定為 'strtolower("\\1")' 字符串,那這樣要如何執行代碼呢?

爬坑1

上面的命令執行,相當于 eval('strtolower("\\1");') 結果,當中的 \\1 實際上就是 \1 ,而 \1 在正則表達式中有自己的含義。我們來看看 W3Cschool 中對其的描述:

反向引用

對一個正則表達式模式或部分模式 兩邊添加圓括號 將導致相關 匹配存儲到一個臨時緩沖區 中,所捕獲的每個子匹配都按照在正則表達式模式中從左到右出現的順序存儲。緩沖區編號從 1 開始,最多可存儲 99 個捕獲的子表達式。每個緩沖區都可以使用 '\n' 訪問,其中 n 為一個標識特定緩沖區的一位或兩位十進制數。

所以這里的 \1 實際上指定的是第一個子匹配項,我們拿 ripstech 官方給的 payload 進行分析,方便大家理解。官方 payload 為: /?.*={${phpinfo()}} ,即 GET 方式傳入的參數名為 /?.* ,值為 {${phpinfo()}}  。

原先的語句: preg_replace('/(' . $regex . ')/ei', 'strtolower("\\1")', $value);
變成了語句: preg_replace('/(.*)/ei', 'strtolower("\\1")', {${phpinfo()}});


爬坑2

上面的 preg_replace 語句如果直接寫在程序里面,當然可以成功執行 phpinfo() ,然而我們的 .* 是通過 GET 方式傳入,你會發現無法執行 phpinfo 函數,如下圖:

我們 var_dump 一下 $_GET 數組,會發現我們傳上去的 .* 變成了 _* ,如下圖所示:

這是由于在PHP中,對于傳入的非法的 $_GET 數組參數名,會將其轉換成下劃線,這就導致我們正則匹配失效。我們可以 fuzz 一下PHP會將哪些符號替換成下劃線,發現有:(這是非法字符不為首字母的情況)

當非法字符為首字母時,只有點號會被替換成下劃線:

所以我們要做的就是換一個正則表達式,讓其匹配到 {${phpinfo()}} 即可執行 phpinfo 函數。這里我提供一個 payload : \S*=${phpinfo()} 執行結果如下:

爬坑3

下面再說說我們為什么要匹配到 {${phpinfo()}} 或者 ${phpinfo()} ,才能執行 phpinfo 函數,這是一個小坑。這實際上是PHP可變變量 的原因。在PHP中雙引號包裹的字符串中可以解析變量,而單引號則不行。 ${phpinfo()} 中的 phpinfo() 會被當做變量先執行,執行后,即變成 ${1} (phpinfo()成功執行返回true)。如果這個理解了,你就能明白下面這個問題:

var_dump(phpinfo()); // 結果:布爾 true
var_dump(strtolower(phpinfo()));// 結果:字符串 '1'
var_dump(preg_replace('/(.*)/ie','1','{${phpinfo()}}'));// 結果:字符串'11'

var_dump(preg_replace('/(.*)/ie','strtolower("\\1")','{${phpinfo()}}'));// 結果:空字符串''
var_dump(preg_replace('/(.*)/ie','strtolower("{${phpinfo()}}")','{${phpinfo()}}'));// 結果:空字符串''
這里的'strtolower("{${phpinfo()}}")'執行后相當于 strtolower("{${1}}") 又相當于 strtolower("{null}") 又相當于 '' 空字符串

總結

這個問題是我們在做 PHP-Audit-Labs 項目的時候發現的,我們盡可能地將每一篇文章的漏洞理解透徹,分析清楚,這對自身也是一種提高。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • PHP preg_replace() 正則替換所有符合條件的字符串
  • PHP 字符串正則替換函數preg_replace使用說明
  • PHP正則替換函數preg_replace和preg_replace_callback使用總結
  • php正則之函數 preg_replace()參數說明
  • 詳解PHP正則表達式替換實現(PHP preg_replace,PHP preg_replace)
  • php中preg_replace正則替換用法分析【一次替換多個值】
  • php preg_replace替換實例講解
  • PHP 正則表達式之正則處理函數小結(preg_match,preg_match_all,preg_replace,preg_split)
  • php中preg_replace_callback函數簡單用法示例
  • php中使用preg_replace函數匹配圖片并加上鏈接的方法

標簽:衡陽 鄂州 崇左 白銀 辛集 綏化 廊坊 太原

巨人網絡通訊聲明:本文標題《深入研究PHP中的preg_replace和代碼執行》,本文關鍵詞  深入研究,PHP,中的,preg,replace,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入研究PHP中的preg_replace和代碼執行》相關的同類信息!
  • 本頁收集關于深入研究PHP中的preg_replace和代碼執行的相關信息資訊供網民參考!
  • 推薦文章
    日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 一级毛片看真人在线视频| 久久国产精品只做精品| 亚洲天堂免费| 欧美激情影院| 美女免费毛片| 亚洲wwwwww| 天堂网中文在线| 欧美日本国产| 高清一级毛片一本到免费观看| 国产亚洲精品aaa大片| 精品国产一区二区三区精东影业| 可以免费看毛片的网站| 欧美大片一区| 日本特黄特色aaa大片免费| 在线观看成人网 | 99热视热频这里只有精品| 香蕉视频久久| 久久精品大片| 国产精品免费久久| 国产福利免费观看| 国产原创中文字幕| 麻豆网站在线看| 黄视频网站免费观看| 中文字幕一区二区三区精彩视频| 国产福利免费视频| 日本免费乱理伦片在线观看2018| 国产精品自拍在线| 欧美一区二区三区在线观看| 国产一区二区精品尤物| 日韩中文字幕一区二区不卡| 一级女性大黄生活片免费| 久久福利影视| 麻豆网站在线看| 精品视频在线观看一区二区三区| 美女免费精品视频在线观看| 国产亚洲精品成人a在线| 日韩综合| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美另类videosbestsex高清 | 青青久久国产成人免费网站| 免费国产在线观看| 中文字幕一区二区三区精彩视频| 国产成人啪精品| 可以免费看毛片的网站| 国产一级强片在线观看| 久草免费在线观看| 91麻豆精品国产自产在线| 91麻豆高清国产在线播放| 日韩专区在线播放| 一级毛片视频播放| 久久久成人影院| 欧美大片毛片aaa免费看| 中文字幕一区二区三区 精品| 国产不卡高清在线观看视频 | 精品国产一区二区三区精东影业| 欧美激情一区二区三区在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久国产精品自线拍免费| 久久精品成人一区二区三区| 99热精品一区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚欧成人乱码一区二区| 精品视频在线观看视频免费视频| 香蕉视频亚洲一级| 欧美一级视频高清片| 日日日夜夜操| 欧美α片无限看在线观看免费| 国产a视频| 欧美激情在线精品video| 精品国产亚洲一区二区三区| 国产一区国产二区国产三区| 成人免费网站久久久| 中文字幕一区二区三区精彩视频| 欧美激情一区二区三区在线播放| 中文字幕一区二区三区 精品| 国产一区二区精品在线观看| 日本免费区| 亚洲 国产精品 日韩| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩一级黄色| 色综合久久天天综线观看 | 国产a毛片| 亚洲精品影院| 成人影院一区二区三区| 亚洲wwwwww| 韩国三级视频在线观看| 韩国三级视频在线观看| 欧美电影免费| 亚洲精品久久玖玖玖玖| 可以免费看污视频的网站| 91麻豆国产福利精品| 一本高清在线| 国产精品免费精品自在线观看| 国产综合成人观看在线| 韩国毛片基地| 欧美国产日韩精品| 免费的黄视频| 日日夜人人澡人人澡人人看免| 国产91精品一区| 久久国产精品永久免费网站| 午夜久久网| 国产精品1024永久免费视频| 天天做日日爱| 一 级 黄 中国色 片| 可以免费看毛片的网站| 欧美激情一区二区三区视频高清 | 成人免费高清视频| 黄视频网站免费看| a级毛片免费观看网站| 九九精品在线| 台湾毛片| 精品视频一区二区| 日本伦理片网站| 久久久久久久男人的天堂| 黄视频网站免费观看| 99久久精品国产高清一区二区| 欧美爱爱网| 欧美激情一区二区三区在线| 亚洲第一页乱| 国产麻豆精品| 香蕉视频亚洲一级| 久久国产一区二区| 日韩专区一区| 欧美大片一区| 国产麻豆精品视频| 国产a视频| 国产成人精品影视| 尤物视频网站在线观看| 麻豆系列 在线视频| 精品久久久久久中文| 香蕉视频久久| 免费一级片在线| 国产亚洲精品成人a在线| 精品视频免费观看| 一本高清在线| 深夜做爰性大片中文| 999久久狠狠免费精品| 欧美激情一区二区三区在线 | 日韩av成人| 色综合久久天天综合| 国产成人精品影视| 一级女性全黄生活片免费| 欧美1区| 国产高清视频免费| 国产一级强片在线观看| 久久国产精品永久免费网站| 国产不卡在线观看| 精品在线观看国产| 成人影视在线观看| 国产综合成人观看在线| 国产成+人+综合+亚洲不卡| 日韩av东京社区男人的天堂| 国产视频久久久| 九九精品久久| 国产一区国产二区国产三区| 97视频免费在线观看| 成人高清护士在线播放| 国产视频一区在线| 国产麻豆精品高清在线播放| 韩国毛片免费| 久久99中文字幕| 国产精品自拍在线| 国产伦精品一区二区三区无广告 | 国产成人啪精品| 国产激情一区二区三区| 精品国产一区二区三区久| 91麻豆精品国产高清在线 | 精品国产香蕉在线播出| 一本高清在线| 国产一区免费在线观看| 精品国产一区二区三区精东影业 | 国产成人啪精品| 日韩中文字幕在线播放| 国产一级生活片| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美激情中文字幕一区二区| 欧美激情一区二区三区中文字幕| 欧美电影免费| 美女免费精品视频在线观看| 黄视频网站在线免费观看| 免费国产一级特黄aa大片在线| 毛片电影网| 亚久久伊人精品青青草原2020| 青青久久精品| 欧美a级大片| 午夜精品国产自在现线拍| 日韩一级黄色片| 精品久久久久久免费影院| 日本免费看视频| 欧美电影免费| 亚洲精品影院| 九九九国产| 超级乱淫黄漫画免费| 久久成人亚洲| 亚洲精品中文一区不卡| 欧美爱爱网| 成人av在线播放| 免费一级片在线观看| 欧美爱色|