news 2026/5/13 12:29:37

polarctf靶场web中等/代码审计1,随机值,你知道sys还能这样玩吗

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
polarctf靶场web中等/代码审计1,随机值,你知道sys还能这样玩吗

1.代码审计1

芝士点:1.原生类读取,形式:大部分是new $a($b)

2.伪协议的利用读全代码

<?php highlight_file(__FILE__); include('flag.php'); $sys = $_GET['sys']; if (preg_match("|flag|", $xsx)) { die("flag is no here!"); } else { $xsx = $_GET['xsx']; echo new $sys($xsx); } >

这个php代码if语句第一部分不会成立,因为xsx还没赋值,所以没有过滤,如果有过滤,,我觉得通配符也可以绕过

一开始我构建sys=system&xsx=flag.php

不通过,因为system是原生函数,不是原生类,在new后面会报错

搜了 一下,可以利用的 原生类有:

1. SplFileObject

作用:PHP 标准库(SPL)中的文件对象类,用于逐行读取、操作文件,是处理文件的核心原生类。

2.File类(部分环境支持,依赖PECL File扩展)

作用:文件操作类,功能和SplFileObject类似,但并非所有 PHP 环境都内置(需要安装 PECL File 扩展)。等

当用文件目录遍历到了敏感文件时,可以用SplFileObject类,同样通过echo触发SplFileObject中的__toString()方法。(该类不支持通配符,所以必须先获取到完整文件名称才行)

但是我用了原生类也没 出来flag

看了wp:

除此之外其实SplFileObject类,只能读取文件的第一行内容,如果想要全部读取就需要用到foreach函数,但若题目中没有给出foreach函数的话,就要用伪协议读取文件的内容。

伪协议解决问题的原理是:伪协议会一次性读取文件全部内容并处理为单行数据流,让SplFileObject的 “第一行” 等于文件的全部内容

注:这里又跟文件包含那种执行不一样,include本身就是一次性读取全部文件内容,不存在 “只读取第一行” 的问题,伪协议在文件包含漏洞中不是为了 “解决单行限制”,而是为了绕过限制、读取源码或执行代码

转成base64,使代码失去执行能力,变成字符串直接读出来

2.随机值


使用&符号,我觉得相当于指针地址符的用法,$a=&$b,把b的值赋值给a

所以可以获得flag

3.你知道sys还能这样玩吗

可以用御剑扫出来,,也可以根据题目提示sys尝试

<?php show_source(__FILE__); if(isset($_POST['cmd'])){ echo "<pre>"; $cmd = $_POST['cmd']; if (!preg_match('/ls|dir|nl|nc|cat|tail|more|flag|sh|cut|awk|strings|od|curl|\*|sort|ch|zip|mod|sl|find|sed|cp|mv|ty|grep|fd|df|sudo|more|cc|tac|less|head|\.|{|}|tar|zip|gcc|uniq|vi|vim|file|xxd|base64|date|bash|env|\?|wget/i', $cmd)) { $output = system($cmd); echo $output; } echo "</pre>"; } ?>

l\s执行成功,但是后面不知道怎么绕过了

但是没有对php过滤,可以考虑使用php -r 在终端执行php函数来实现二次命令执行

<?php // 要执行的命令 $command = ''; // 将命令转换为十六进制编码 $hexCommand = bin2hex($command); // 构造 PHP 代码,将十六进制命令解码后传递给 eval 函数执行 $phpCode = 'system(hex2bin("' . $hexCommand .'"));'; // 执行 PHP 代码 echo($phpCode); ?>

依次执行命令,ls ../../../

发现flag.txt,,执行cat ../../../flag,.txt

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/4 11:53:19

Piper开发调试实战指南:3大核心技巧加速游戏设备配置开发

Piper开发调试实战指南&#xff1a;3大核心技巧加速游戏设备配置开发 【免费下载链接】piper GTK application to configure gaming devices 项目地址: https://gitcode.com/gh_mirrors/pip/piper Piper作为专业的游戏设备配置GTK应用程序&#xff0c;为开发者提供了高效…

作者头像 李华
网站建设 2026/5/12 23:55:00

jQuery-Cookie到JS Cookie技术迁移完整指南:高效版本升级最佳实践

jQuery-Cookie到JS Cookie技术迁移完整指南&#xff1a;高效版本升级最佳实践 【免费下载链接】jquery-cookie No longer maintained, superseded by JS Cookie: 项目地址: https://gitcode.com/gh_mirrors/jq/jquery-cookie 在当前前端技术快速迭代的背景下&#xff0c…

作者头像 李华
网站建设 2026/5/9 18:56:32

【2024最新】Zalando RESTful API设计准则深度解析与实战指南

【2024最新】Zalando RESTful API设计准则深度解析与实战指南 【免费下载链接】restful-api-guidelines A model set of guidelines for RESTful APIs and Events, created by Zalando 项目地址: https://gitcode.com/gh_mirrors/re/restful-api-guidelines 在微服务架构…

作者头像 李华
网站建设 2026/5/1 19:45:59

Keploy Serverless测试:零代码自动化测试的革命性突破

Keploy Serverless测试&#xff1a;零代码自动化测试的革命性突破 【免费下载链接】keploy Test generation for Developers. Generate tests and stubs for your application that actually work! 项目地址: https://gitcode.com/GitHub_Trending/ke/keploy 我们发现&a…

作者头像 李华
网站建设 2026/5/10 19:59:30

JAX多精度计算实战:3大技巧提升深度学习模型性能

在深度学习模型部署过程中&#xff0c;你是否面临这样的困境&#xff1a;高精度模型推理缓慢&#xff0c;低精度模型准确性堪忧&#xff1f;JAX框架的多精度计算能力正是解决这一痛点的利器。本文将带你深入了解JAX数值类型系统的特性&#xff0c;掌握3大核心优化技巧&#xff…

作者头像 李华
网站建设 2026/5/12 14:21:52

告别Vim碎片化搜索:Unite.vim统一界面全攻略

告别Vim碎片化搜索&#xff1a;Unite.vim统一界面全攻略 【免费下载链接】unite.vim :dragon: Unite and create user interfaces 项目地址: https://gitcode.com/gh_mirrors/un/unite.vim 还在为Vim中各种搜索命令记不住而烦恼吗&#xff1f;Unite.vim就是你的救星&…

作者头像 李华