0

0

字符串处理如何触发php代码执行_字符串处理触发php代码执行方法【指南】

蓮花仙者

蓮花仙者

发布时间:2025-12-24 18:18:10

|

524人浏览过

|

来源于php中文网

原创

PHP中eval、assert、动态函数调用及preg_replace的/e修饰符均可因用户输入未过滤导致远程代码执行。

字符串处理如何触发php代码执行_字符串处理触发php代码执行方法【指南】

如果在PHP应用中对用户输入的字符串进行不当处理,可能导致恶意代码被解释执行。以下是几种常见的触发方式:

一、使用eval函数处理未过滤的字符串

eval函数会将传入的字符串作为PHP代码解析并执行。当用户可控的字符串未经校验直接送入eval时,即可触发任意代码执行。

1、获取用户提交的参数,例如通过$_GET['code']接收字符串内容。

2、将该参数直接拼接进eval语句,如:eval("echo " . $_GET['code'] . ";");。

立即学习PHP免费学习笔记(深入)”;

3、构造payload,例如提交code=phpinfo(),使服务器执行phpinfo()函数。

4、确认执行结果是否在响应中返回phpinfo()输出内容

二、利用assert函数执行字符串代码

assert在PHP 7以下版本中可接受字符串参数并将其作为PHP代码执行,与eval行为类似,常被忽略其危险性。

1、检查代码中是否存在assert($_GET['x'])这类调用。

2、确认PHP版本是否低于7.0(如5.6或5.4)。

3、发送请求,例如?x=system('ls'),观察目录列表是否出现在响应中。

4、若页面回显当前目录下的文件名列表,说明assert已成功执行系统命令。

三、动态函数调用配合用户输入

当函数名由用户控制且未加白名单限制时,可通过字符串拼接实现函数调用,进而执行危险操作。

1、定位类似${$_GET['func']}()或$func = $_GET['func']; $func();的代码结构。

Subtxt
Subtxt

生成有意义的文本并编写完整的故事。

下载

2、确认目标函数是否存在于当前环境中,例如shell_exec、passthru、system等。

3、构造请求,例如?func=system&cmd=id,使system函数被执行。

4、响应中若包含uid=0(root) gid=0(root)等信息,则表明命令执行成功。

四、preg_replace的/e修饰符注入(PHP 5.4及更早)

在旧版PHP中,preg_replace使用/e修饰符时会将替换字符串作为PHP代码执行,极易导致远程代码执行。

1、查找形如preg_replace("/.*/e", $_GET['p'], "test")的代码段。

2、确认PHP版本是否启用/e修饰符支持(PHP

3、提交payload,例如p=phpinfo(),使正则替换触发代码执行。

4、响应中若出现PHP版本、扩展、配置等详细信息,即表示漏洞已被触发。

五、反序列化过程中字符串参与动态调用

当反序列化对象的魔术方法(如__wakeup、__destruct)中存在基于字符串拼接的函数调用或变量调用时,可能触发代码执行。

1、识别类中是否存在类似call_user_func($_SERVER['HTTP_X_FUNC'])的调用逻辑。

2、构造恶意序列化字符串,使反序列化后$_SERVER['HTTP_X_FUNC']被设为system。

3、在HTTP请求头中添加X-Func: system,并携带序列化数据到接收点。

4、若响应中返回命令执行结果(如whoami输出),说明反序列化链已成功利用。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1640

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1078

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

979

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1226

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1437

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1302

2023.11.13

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 7.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号