php eval函数用法总结

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

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); 
   

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

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

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); 
   

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


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值