<?php
$str = 'echo "hello";';
$content = eval($str);
echo ',word!';
?>
执行结果: hello,word!
一、把 字符串 作为 php脚本处理。相信这个大家都知道!
<?php
$str = '你好,世界! echo "Hello,";';
$content = eval($str);
echo 'word!';
// 执行结果:
/*
Parse error: syntax error, unexpected 'echo' (T_ECHO) in E:webwwwswoole_testeval.php(4) : eval()'d code on line 1 word!
*/
?>
二、当 字符串 里有不合法的php代码时,报错。相信大家也都知道!
<?php
$str = '你好,世界! echo "Hello,";';
$content = eval('?>'.$str); // 注意,此时eval里 加了 "?>" 字符串
echo 'word!';
// 执行结果:
/*
你好,世界! echo "Hello,";word!
*/
?>
三、此时,字符串里面有不合法的 php 代码,但是,不报错了。
---因为前面加了"?>"(php结束符),它已经将后面的“字符串”全部当作“字符串”了,是吧!
下面在(三)的基础上,在字符串里嵌入<?php ... ?>模块,相当于html文件里嵌入 php代码一样。它会怎样呢?
<?php
$str = '你好,世界! <?php echo "Hello,"; ?>';
$content = eval('?>'.$str);
echo 'word!';
// 执行结果:
/*
你好,世界! Hello,word!
*/
?>
OK!它会识别 “字符串” 里的 php模块并执行!
上面的例子其实说明了 eval('?>'.$str) 和 eval($str)的作用。
其实,eval($str)的 $str 里面,
如果字符串包含有<?php ... ?>时,
那么$str字符串就必须在<?php ... ?>前加上 “?>”个php的结束符。