PHP eval() 函数

Posted 一坪海岸线y

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP eval() 函数相关的知识,希望对你有一定的参考价值。

定义和用法

eval() 函数把字符串按照 php 代码来计算。

该字符串必须是合法的 PHP 代码,且必须以分号结尾。

如果没有在代码字符串中调用 return 语句,则返回 NULL。如果代码中存在解析错误,则 eval() 函数返回 false。

语法

eval(phpcode)

  

参数描述
phpcode 必需。规定要计算的 PHP 代码。

 

提示和注释

注释:返回语句会立即终止对字符串的计算。

注释:该函数对于在数据库文本字段中供日后计算而进行的代码存储很有用。

例子

<?php
$string = "beautiful";
$time = "winter";
 
$str = ‘This is a $string $time morning!‘;
echo $str. "<br />";
 
eval("\$str = \"$str\";");
echo $str;
?>   

输出:

This is a $string $time morning!
This is a beautiful winter morning!
 



eval() 函数在CodeIgniter框架里也有用到。在 /system/database/DB.php 文件中,根据系统的配置动态的定义了一个类 CI_DB,具体代码片段如下:
if ( ! isset($active_record) OR $active_record == TRUE)
    {
        require_once(BASEPATH.‘database/DB_active_rec.php‘);
 
        if ( ! class_exists(‘CI_DB‘))
        {
            eval(‘class CI_DB extends CI_DB_active_record { }‘);
        }
    }
    else
    {
        if ( ! class_exists(‘CI_DB‘))
        {
            eval(‘class CI_DB extends CI_DB_driver { }‘);
        }
    }
 
    require_once(BASEPATH.‘database/drivers/‘.$params[‘dbdriver‘].‘/‘.$params[‘dbdriver‘].‘_driver.php‘);
 
    // Instantiate the DB adapter
    $driver = ‘CI_DB_‘.$params[‘dbdriver‘].‘_driver‘;
    $DB = new $driver($params);

以上是关于PHP eval() 函数的主要内容,如果未能解决你的问题,请参考以下文章

php eval函数一句话木马代码

php eval() 函数可以将一个字符串当做 php 代码来运行

PHP常见代码执行后门函数

PHP 一句话木马

PHP eval函数

从 PHP 函数中删除 eval [关闭]