PHP代码审计 03 代码执行

PHP代码审计学习
本文介绍PHP代码审计的基础知识,重点讲解eval、assert及preg_replace等常见代码执行函数,并通过实例展示如何利用这些函数进行安全审查。

本文记录 PHP 代码审计的学习过程,教程为暗月 2015 版的 PHP 代码审计课程

PHP 代码审计博客目录

1. 简介

  1. 常见代码执行函数

    eval 、assert 、preg_replace

2. 代码执行函数示例

  1. eval() 函数

    eval()函数中的eval是evaluate的简称,这个函数的作用就是把一段字符串当作PHP语句来执行,一般情况下不建议使用,容易被黑客利用

     <?php
     if(isset($_GET['moon']));{
     	$moon=$_GET['moon'];
     	eval("\$moon = $moon;");
     }
     ?>
    

    浏览器执行 http://127.0.0.1/test.php?moon=phpinfo();

    在这里插入图片描述

  2. assert() 函数

    assert()这个函数在php语言中是用来判断一个表达式是否成立。返回true or false;

     <?php
     if(isset($_GET['moon']));{
     	$moon=$_GET['moon'];
     	assert("\$moon = $moon;");
     }
     ?>
    

    浏览器执行 http://127.0.0.1/test.php?moon=phpinfo();

    在这里插入图片描述

  3. preg_replace() 函数

    preg_replace(pattern,replacement,subject,limit,count)

    搜索 subject 中匹配 pattern 的部分, 以 replacement 进行替换。官方文档说明

    其中pattern为正则表达式(字符串或者字符串);
    replacement是用于替换的字符串或字符串数组,replacement可以包含 \n 形式或者 $n 形式的逆向引用,首选使用后者。每个此种引用将被替换为与第 n 个被捕获的括号内的子模式所匹配的文本。n 可以从0到99,其中 \0 或者 $0 指的是被整个模式所匹配的文本。对左圆括号从左到右计数(从1开始)以取得子模式的数;
    subject,为要进行搜索和替换的字符串或者字符串数组;
    limit,可选,是每个模式在subject上进行替换的最大次数。默认是-1(无限);
    count,可选,完成的替换次数。

     第一个参数注入:
     	<?php
     	echo $reg = $_GET['reg'];
     	$var = '<php>phpinfo()</php>';
     	preg_replace("/<php>(.*?)$reg", '\\1', $var);
     	?>
    

    浏览器执行 http://127.0.0.1/test.php?reg=</php>/e

在这里插入图片描述

	第二个参数注入:			
		<?php
		preg_replace("/moon/e",$_GET['moon'],"I love moon");
		?>

浏览器执行 http://127.0.0.1/test.php?moon=phpinfo()

![在这里插入图片描述](https://img-blog.csdnimg.cn/20190413173525151.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0tldmluaGFuc2Vy,size_16,color_FFFFFF,t_70)


	第三个参数注入:
		<?php
		preg_replace("/\s*\[php\](.+?)\[\/php\]\s*/ies", "\\1", $_GET['moon']);
		?>

浏览器执行 http://127.0.0.1/test.php?moon=[php]phpinfo()[/php]

![在这里插入图片描述](https://img-blog.csdnimg.cn/20190413173529617.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0tldmluaGFuc2Vy,size_16,color_FFFFFF,t_70)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值