php专区

 首页 > php专区 > PHP应用 > php函数大全 > php eval函数用法总结 - php函数

php eval函数用法总结 - php函数

分享到:
【字体:
导读:
          这个函数我想很多朋友都知道,黑客用得最多的一句了,可以解析php 代码并且运行,eval是函数不可在php中禁止,以前我就以为可以在php.ini禁止此函数,结果失败了.定义和用法eval() 函数把字符...

php eval函数用法总结

这个函数我想很多朋友都知道,黑客用得最多的一句了,可以解析php 代码并且运行,eval是函数不可在php中禁止,以前我就以为可以在php.ini禁止此函数,结果失败了.

定义和用法

eval() 函数把字符串按照 PHP 代码来计算,该字符串必须是合法的 PHP 代码,且必须以分号结尾,如果没有在代码字符串中调用 return 语句,则返回 NULL,如果代码中存在解析错误,则 eval() 函数返回 false.

语法:eval(phpcode) 

参数 描述

phpcode 必需,规定要计算的 PHP 代码.

提示和注释

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

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

PHP实例代码如下:

  1. $string = "beautiful";  
  2. $time = "winter";  
  3.    
  4. $str = 'This is a $string $time morning!';  
  5. echo $str"";  
  6.    
  7. eval("$str = "$str";");  
  8. echo $str;  
  9. ?>     
  10. //输出: 
  11. //This is a $string $time morning! 
  12. //This is a beautiful winter morning! 

eval() 函数在CodeIgniter框架里也有用到,在 /system/database/DB.php 文件中,根据系统的配置动态的定义了一个类 CI_DB,具体代码片段如下:

  1. if ( ! isset($active_record) OR $active_record == TRUE)  
  2.     {  
  3.         require_once(BASEPATH.'database/DB_active_rec.php');  
  4.    
  5.         if ( ! class_exists('CI_DB'))  
  6.         {  
  7.             eval('class CI_DB extends CI_DB_active_record { }');  
  8.         }  
  9.     }  
  10.     else 
  11.     {  
  12.         if ( ! class_exists('CI_DB'))  
  13.         {  
  14.             eval('class CI_DB extends CI_DB_driver { }');  
  15.         }  
  16.     }  
  17.    
  18.     require_once(BASEPATH.'database/drivers/'.$params['dbdriver'].'/'.$params['dbdriver'].'_driver.php');  
  19.    
  20.     // Instantiate the DB adapter,phpfensi.com
  21.     $driver = 'CI_DB_'.$params['dbdriver'].'_driver';  
  22.     $DB = new $driver($params);  

本函式可将字符串之中的变量值代入,通常用在处理数据库的数据上,参数 code_str 为欲处理的字符串,值得注意的是待处理的字符串要符合 PHP 的字符串格式,同时在结尾处要有分号,使用本函式处理后的字符串会沿续到 PHP 程序结束.

分享到:
PHP addslashes 的高级写法 - php函数
PHP addslashes 的高级写法 本文章介绍了用户自定义的addslashes函数,他可以自动过滤,post,get过来的非法数据,实例代码如下: @set_magic_quotes_runtime(0);   $MQG = get_magic_quotes_gpc();     if(!$MQG && $_POST) $_POST = daddslashes($_POST);   if(!$MQG...
php防注入过滤客户提交$_GET 和$_POST参...
php防注入过滤客户提交$_GET 和$_POST参数 下面一款防止php页面给sql注入的一个程序代码,有需要的朋友可参考,以下代码实现过滤php的$_GET 和$_POST参数. php防注入过滤客户提交$_GET 和$_POST参数实例代码如下: /**  * 安全防范  */  function Add_S($array)  {//开源代...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……