eval(cmd)与eval($cmd)的区别与联系

admin3年前PHP教程37

这个问题一直困扰我许久,今天终于解决清楚了

问题1:eval的执行是否需要双引号包括:

先看三个命令:


a:<?php eval(system(dir))?>
b:<?php
    $cmd="system(dir)";
    eval($cmd)?>


a结果:

b结果:

报错

思考:

同样是一个命令,为什么会出现如此区别,询问了其他师傅得知:eval执行的是变量的值的时候,该变量值需要闭合,也就是必须是一个完整的语句,需要用分号结尾。根据这个道原理我们改一下上面的命令看看:


<?php
    $cmd="system(dir);";
    eval($cmd)?>


结果:


发现是可以执行的。

后话:

关于这个点,还需要补充一个:

内置函数在eval里面直接执行时不需要加分号,看两个命令就知道了:


eval(system(dir));
eval(system(dir););


内置函数不需要加分号,其实我觉得加不加分号都一样,因为加了分号就要加引号,引号也带有解析的意思

理解一下命令执行中的闭合:

看代码:


eval(system(dir));
eval(system(dir););


看看结果:

这里可以并且后面语句是不影响解析的


<?php
    eval("system(dir);?>xyusaiqeqcyuqqwdnoqcq");
    ?>


我们这里都是不影响的,为什么?

如果我们是简单的闭合eval这个命令

那我们的playload应该是:


<?php
    eval("system(dir));?>xyusaiqeqcyuqqwdnoqcq");
?>
上面的代码我错误的理解成:
<?php
    eval("system(dir)");?>
    xyusaiqeqcyuqqwdnoqcq");
?>


之前我错误的以为是这样的闭合的,但是后来发现我错了,直到在有一道题目中我发现这样闭合不了,后面询问了一下其他师傅,得到答案:

eval()这个函数可以理解成我们是将eval(字符串)这里面的字符串放到了一个新的php里面去运行,这个新的php本来就又 <?php 所以当我们传入 system(dir);?>dasdas的时候,?>就以及阶段了php代码

学习了~

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

新加坡大带宽服务器租赁哪个好

新加坡大带宽服务器租赁哪个好?选择新加坡大带宽服务器租赁服务提供商时,可以考虑以下几个方面:服务质量:服务质量是选择服务器租赁服务提供商的重要因素,可以查看用户评价、客户支持服务等方面,选择一家有良好...

棋牌游戏服务器的搭建面临哪些问题?租用美国BGP高防服务器哪家比较好?

棋牌游戏是棋盘游戏和牌类游戏的统称,早在明清时期开始就一度兴盛。从出现以来,棋牌游戏都吸引了众多爱好者,以前人们大多都是面对面一起对弈,然而随着互联网的发展,为满足棋牌爱好者的需求,互联网上出现了许多...

PHP之CI框架学习讲解

一、前言CodeIgniter 是一个简单快速的PHP MVC框架。EllisLab 的工作人员发布了 CodeIgniter。CodeIgniter 是一套小巧但功能强大的、给 PHP 网站开发者使...

如何选择成都gpu服务器的配置

随着人工智能和大数据技术的快速发展,GPU服务器已经成为了许多企业和机构进行深度学习、图像处理等高性能计算任务的重要工具。选择一台适合自己需求的GPU服务器,将会极大地提高计算效率和数据处理能力。然而...

分析PHP的垃圾回收机制

如果用过C语言,那么申请内存的方式是malloc或者是calloc,然后你用完这个内存后,一定不要忘了用free函数去释放掉,这就是传说中手动垃圾回收,一般都是扫地神僧用这种方式。很多高层次语言中,你...

游戏出海东南亚服务器应该怎么选择

游戏出海东南亚服务器应该怎么选择?如果您想将游戏出海到东南亚市场并选择服务器,以下是几个因素应该考虑:延迟和稳定性:选择距离目标用户更近的服务器可以减少延迟,提供更稳定的连接。这对于需要实时交互的多人...