转自:‘http://yige.org/p/657’
<?php
03 | $str = '你好,世界! echo "Hello,";' ; |
二、当 字符串 里有不合法的php代码时,报错。相信大家也都知道!
03 | $str = '你好,世界! echo "Hello,";' ; |
04 | $content = eval ( '?>' . $str ); |
三、此时,字符串里面有不合法的 php 代码,但是,不报错了。
---因为前面加了"?>"(php结束符),它已经将后面的“字符串”全部当作“字符串”了,是吧!
下面在(三)的基础上,在字符串里嵌入<?php ... ?>模块,相当于html文件里嵌入 php代码一样。它会怎样呢?
03 | $str = '你好,世界! <?php echo "Hello,"; ?>' ; |
04 | $content = eval ( '?>' . $str ); |
OK!它会识别 “字符串” 里的 php模块并执行!
上面的例子其实说明了 eval('?>'.$str) 和 eval($str)的作用。
其实,eval($str)的 $str 里面,
如果字符串包含有<?php ... ?>时,
那么$str字符串就必须在<?php ... ?>前加上 “?>”个php的结束符。
在Ecshop的模版引擎里面,就用了eval('?>'.$str)这种方法,来解析模版中嵌入的php模块---当然在此之前,先将标签解析翻译成了php代码。