Analyser et gérer la fonction eval en PHP
<p>Avertissement : Ceci est juste un exemple pour apprendre l'injection de code PHP, et non du code de production à utiliser de quelque manière que ce soit. Je suis pleinement conscient que ce n'est pas une bonne pratique de codage. </p>
<p>J'ai le script PHP suivant : </p>
<pre class="brush:php;toolbar:false;"><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
<tête>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>Exemple de script</title>
≪/tête>
<corps>
<h1>Page d'exemple</h1>
<p>Maintenant, passons aux mathématiques. Veuillez entrer une formule pour calculer. Par exemple : 1+1. </p>
<form method="get">
<p>Formule : <input type="text" name="maths" /></p>
<p><input type="submit" value="calculate" /></p>
</formulaire>
<?
if (( isset($_REQUEST["maths"])) && ($_REQUEST["maths"] != "") )
{
echo "<p>Le résultat est :" ;
eval("echo (".$_REQUEST["maths"].");");
echo "</p>";
}
?>
</corps>
</html></pre>
<p>Ce script est vulnérable à l'injection de code PHP, j'ai pu le casser en procédant comme suit (principalement découvert par essais et erreurs) : </p>
<pre class="brush:php;toolbar:false;">$a='1');phpinfo();echo($a</pre>
<p>Cependant, je ne comprends pas entièrement la raison. D'après ce que j'ai compris, je dois compléter l'instruction echo, insérer mon propre code (par exemple phpinfo()), puis écrire une autre fonction (par exemple echo) pour gérer le crochet fermant. </p>
<p>Je pensais qu'un code comme celui-ci fonctionnerait :</p>
<pre class="brush:php;toolbar:false;">");phpinfo();echo("</pre>
<p>Cependant, cela ne fonctionne pas car phpinfo est considéré comme faisant partie de la chaîne et n'est pas évalué par la fonction eval.
J'ai également essayé d'échapper aux guillemets sans succès. </p>
<p>Question :</p>
<ul>
<li>Quelle est la bonne façon d’injecter du code ici ? ≪/li>
<li>Pourquoi<code>$a='1');phpinfo();echo($a</code> fonctionne-t-il ?</li>
</ul><p><br /></p>