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

polarctf-web-[某函数的复仇]

考点:

匿名构造函数(create_function)

题目来源:polarctf-web-[某函数的复仇]

解题:

代码审计:

 <?phphighlight_file(__FILE__);//flag:/flagif(isset($_POST['shaw'])){$shaw = $_POST['shaw'];$root = $_GET['root'];if(preg_match('/^[a-z_]*$/isD',$shaw)){if(!preg_match('/rm|ch|nc|net|ex|\-|de|cat|tac|strings|h|wget|\?|cp|mv|\||so|\$/i',$root)){$shaw('',$root);}else{echo "Almost there^^";}}}?>
正则表达式 /^[a-z_]*$/isD 讲解​^:这是一个锚点,表示匹配字符串的开始。它确保了正则表达式从字符串的最开始位置开始匹配。​[a-z_]:这是一个字符集,它匹配小写字母(a-z)和下划线(_)。在这个字符集内,任何一个字符都会被认为是有效的匹配字符。​*:这是量词,表示匹配前面的字符集零次或多次。也就是说,这个正则表达式会匹配由小写字母和下划线组成的字符串,长度可以为零(空字符串也可以匹配)。​$:这是另一个锚点,表示匹配字符串的结束。它确保了正则表达式从字符串的最末尾结束匹配。​i(修饰符):这是一个正则表达式的标志,表示忽略大小写。在这个表达式中,a-z 会匹配所有字母,无论是大写还是小写。因此,[a-z_] 会匹配字母(大小写都可以)和下划线。​s(修饰符):这个修饰符表示“dotall”模式,在这个模式下,.(点号)可以匹配换行符。虽然这个正则表达式本身并没有使用.,但如果它用于更复杂的表达式中,s标志会让dot匹配所有字符,包括换行符。​D(修饰符):这是“Unicode修饰符”的一个变种。它限制了正则表达式的匹配字符只能是单字节的字符,在一些特定的环境中,D可能会影响匹配行为,但它在普通正则表达式中并不常见。

使用动态创建匿名函数的函数create_function

解题payload:

create_function漏洞详细解析

create_function('', $root)执行时,它在PHP内部实际上是这样工作的:

  1. PHP会动态创建一个匿名函数,大致如下:

     function anonymous() {这里是$root的内容}
  2. 当我们传入$root = }system(%22s\ort%20/flag%22);/*时,PHP实际生成的代码就变成了:

     function anonymous() {}system("s\ort /flag");/*}
  3. 注意看第一个},它提前闭合了函数定义的大括号,使后面的代码跳出了函数体的范围

  4. 接着system("s\ort /flag")会作为独立的PHP代码执行,而不是函数体内的代码

  5. 最后/*是多行注释的开始,它注释掉了后面所有内容(包括函数定义末尾多余的}),防止PHP解析出语法错误

相关文章:

  • webpack5所用依赖以及对应的版本
  • 【25软考网工】第七章(3) UOS Linux防火墙配置和Web应用服务配置
  • springboot+vue实现鲜花商城系统源码(带用户协同过滤个性化推荐算法)
  • 七彩喜防摔马甲:科技守护银发安全的“隐形铠甲”
  • [特殊字符] 遇见Flask
  • 人脸识别,使用 deepface + api + flask, 改写 + 调试
  • AI办公提效,Deepseek + kimi生成ppt
  • SRS流媒体服务器,配置国标协议对接和HTTPS视频流输出功能
  • 以加减法计算器为例,了解C++命名作用域与函数调用
  • 词向量(Word Embedding)深度解析
  • iPaaS集成平台技术选型关注哪些指标?
  • TCP网络编程学习
  • 【JAVA】中文我该怎么排序?
  • 豪越智能仓储:为消防应急物资管理“上锁”
  • PyTorch进阶实战指南:02分布式训练深度优化
  • 使用Tkinter写一个发送kafka消息的工具
  • 如何从 iPhone 获取照片:5 个有效解决方案
  • 【鸿蒙开发】Hi3861学习笔记-DHT11温湿度传感器
  • window 显示驱动开发-设置内存分配的大小和间距
  • Redis Cluster动态扩容:架构原理与核心机制解析
  • 设计师必看的10个网站/创建免费网站
  • 手把手教你优化网站/2024年的新闻
  • 网站建设有哪些平台/友情链接交换标准
  • 做药品的电商网站有哪些/百度网站首页网址
  • 阿里云建站教程视频/今日百度搜索风云榜
  • 如何查到别人的网站做哪些竞价词/怎么优化推广自己的网站