php5和php7中eval和assert

eval

php官方手册:

(PHP 4, PHP 5, PHP 7)

eval — 把字符串作为PHP代码执行

该函数只有一个参数,即需要被执行的字符串代码。

代码不能包含打开/关闭PHP标签,但可以用合适的 PHP tag 来离开、重新进入 PHP 模式。

我们下面进行测试
记住要用 ;结尾

<?php
eval(' echo "Hi!"; ');
echo "\n";
//eval('echo `whoami`;');
eval('<?php echo "Hi!";?>');
echo "\n";
eval('?><?php echo "Hi!";?>');
echo "\n";
eval('echo "Hi"?><?php echo "Hi!";?>');

QQ截图20201204165203.png

可以发现我们如果 存在<?php 的标签时会报错,但是如果我们先 ?>将前面的php标签闭合,我们后面就能使用php标签了

可执行系统函数

QQ截图20201204172946.png

tip:

在php的配置文件php.ini中有一个short_open_tag的值,开启以后可以使用PHP的短标签:<? ?>同时,只有开启这个才可以使用 <?= 以代替 <? echo。不过在php7中这个标签被移除了。

eval只能执行一次

<?php
error_reporting(0);
    $a='assert';
    $b='system';
    $c='whoami';
    //echo $a($c);
    echo "\n";
    echo "\n";
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值