CTF题(JSON弱类型) 首页只有 data:image/s3,"s3://crabby-images/2d44f/2d44f79ded6b00f9621248bb4a39cf2f0670a7fb" alt="首页功能" 其中有游客不允许访问 查看cookie data:image/s3,"s3://crabby-images/71397/713976c55aa7a866a678e45489799c3bfbac1bff" alt="在这里插入图片描述" 很明显authe是JSON转换的 则把authe转回去 data:image/s3,"s3://crabby-images/25cd7/25cd726cb00de5f1166f9f25f7a4804271a3614c" alt="在这里插入图片描述" 在这里可以看到guest(游客) 把cookie里面改成admin的 data:image/s3,"s3://crabby-images/9aac7/9aac7d951ec67685751231c1c03f2c64b67b22d3" alt="在这里插入图片描述" 但是网页没变化(8个?表示不确定的数值,乱填等于瞎搞爆破没意义) 只能查看源码了(这里可以下载到源码我这里是后面加.bak) data:image/s3,"s3://crabby-images/7821b/7821b353896ef12ce21e848ca36c9652d8ebdb36" alt="在这里插入图片描述" <?php require("header.php"); include_once("config/config.php"); if(!isset($_COOKIE['authe'])){ //secret_is_'hash.??????' $autharr=array( 'role'=>'guest', 'passnum'=>'????????' ); $auth= json_encode($autharr); ob_start(); setcookie('authe', $auth); ob_end_clean(); $_SESSION['isguest']=true; }else{ $temp=$_COOKIE['authe']; $data=json_decode($temp); $num=$data->passnum; if(json_last_error() != JSON_ERROR_NONE){ echo "json error"; exit(); } if($num!=="????????"){ for ($i=0; $i < 7; $i++) { //secret num is random generated that you can't guess, only admin can enter this site. if(!($num[$i]==$secretnum[$i])) { echo "random secret num error"; exit(); } } if($data->role==='admin'){ $_SESSION['isguest']=false; } } } $page=""; if (isset($_GET['page'])) { $page=strtolower($_GET['page']); $page=str_replace("#", "", $page); $page=str_replace("'", "", $page); if(strpos($page,"config")!==false) exit(); if(strpos($page,"phar")!==false||strpos($page,"zip")!==false||strpos($page,"data")!==false) exit(); $page=$_GET['page'].".php"; } else $page="main.php"; if(!isset($_SESSION['isguest'])||$_SESSION['isguest']===true) { echo "游客(guest)不允许访问更多功能"; exit(); } include($page); ?>
这里是原文规格的
<?php
require("header.php");
include_once("config/config.php");
if(!isset($_COOKIE['authe'])){
$autharr=array(
'role'=>'guest',
'passnum'=>'????????'
);
$auth= json_encode($autharr);
ob_start();
setcookie('authe', $auth);
ob_end_clean();
$_SESSION['isguest']=true;
}else{
$temp=$_COOKIE['authe'];
$data=json_decode($temp);
$num=$data->passnum;
if(json_last_error() != JSON_ERROR_NONE){
echo "json error";
exit();
}
if($num!=="????????"){
for ($i=0; $i < 7; $i++) {
if(!($num[$i]==$secretnum[$i]))
{
echo "random secret num error";
exit();
}
}
if($data->role==='admin'){
$_SESSION['isguest']=false;
}
}
}
$page="";
if (isset($_GET['page']))
{
$page=strtolower($_GET['page']);
$page=str_replace("#", "", $page);
$page=str_replace("'", "", $page);
if(strpos($page,"config")!==false)
exit();
if(strpos($page,"phar")!==false||strpos($page,"zip")!==false||strpos($page,"data")!==false)
exit();
$page=$_GET['page'].".php";
}
else
$page="main.php";
if(!isset($_SESSION['isguest'])||$_SESSION['isguest']===true)
{
echo "游客(guest)不允许访问更多功能";
exit();
}
include($page);
?>
在这里的源码可以知道一些信息 data:image/s3,"s3://crabby-images/a89e3/a89e38aa1c8fb3565237130b67a4b6d034bf29fd" alt="在这里插入图片描述"
即需要将 data:image/s3,"s3://crabby-images/08541/08541fdd5ff16b9f12e341a0ce842d095c8e895e" alt="在这里插入图片描述" 变成FLASE就可以绕过游客登陆了 那么怎么变成FALSE呢,全文只有这里了 data:image/s3,"s3://crabby-images/6ce3d/6ce3d6909ac943f3a74a8586632beef6317ff90b" alt="在这里插入图片描述"
要么就是一开始就没有设置值(也就是) data:image/s3,"s3://crabby-images/a34c4/a34c4e3b2c653cb463412514e6ecebe228cce2e7" alt="在这里插入图片描述"
忽略但是这个不现实 因为这是设置cookie 所以还是要去绕过for循环,这里就有一个JSON的弱类型利用,我们将cookie的usernum变成数组【true,ture。。。。。】这样在循环里面就可以全部绕过 Cookie的JSON修改为 data:image/s3,"s3://crabby-images/5b941/5b941f0af37678d97a32d1fcb24b5317605d9120" alt="在这里插入图片描述"
好现在转换成url进cookie data:image/s3,"s3://crabby-images/60314/603148fd47c9714a2995ea1aecfaab36f04419ac" alt="在这里插入图片描述"
Cookie现在为 这样就绕过了游客登陆 data:image/s3,"s3://crabby-images/e9456/e9456ee6ab4f9d6b0b23e501b53df34af0e9c33e" alt="在这里插入图片描述"
现在上传图片 现在先验证功能(上传正经图片来验证) data:image/s3,"s3://crabby-images/a3b8f/a3b8fd5c7ae016eafaced965d34e55609b54841a" alt="在这里插入图片描述"
出现 data:image/s3,"s3://crabby-images/e1859/e1859ac9ba32ea8b3c226b38108f03bac8fbfedb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/be675/be6750e14a933d2026d6d35055a13d67222021ab" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/37655/376558e41cafe88d2e65e136dfd097e9f65755f0" alt="在这里插入图片描述"
无论png还是.png都是这样 没办法了 只能去尝试看源码,源码怎么找呢 看url 这里出现了文件包含 那就用php://filter去看 data:image/s3,"s3://crabby-images/15888/15888a9bc8906734e51f9a1079cfb8e471d4d8fd" alt="在这里插入图片描述"
注意这里后面没有.php所以后面的(其实index里面也有写为什么这里就不说了) data:image/s3,"s3://crabby-images/adcd8/adcd89b7b46e4f19fc1590638ad01e9087b12d0a" alt="在这里插入图片描述"
这里后面没有.php data:image/s3,"s3://crabby-images/1d81f/1d81fe22c5c8785d3b8d0cb753c4727fb077834b" alt="在这里插入图片描述"
解码后看源码 Php源码部分
<?php
include_once("config/config.php");
if(!isset($_SESSION['isguest'])||$_SESSION['isguest']===true)
{
echo "游客不允许访问";
exit();
}
$error=$_FILES['pic']['error'];
$tmpName=$_FILES['pic']['tmp_name'];
$name=$_FILES['pic']['name'];
$size=$_FILES['pic']['size'];
$type=$_FILES['pic']['type'];
try{
if($name!=="")
{
$name1=substr($name,-4);
if(is_uploaded_file($tmpName)){
$time=time();
$file=md5($name);
$rootpath='uploads/'.$file.$name1;
if(!move_uploaded_file($tmpName,$rootpath)){
echo "<script language='JavaScript'>alert('文件移动失败!');window.location='index.php?page=submit'</script>";
exit;
}
else{
if($name1===".php"){
file_put_contents($rootpath,preg_replace("/<\?/","",file_get_contents($rootpath)));
}
}
}
echo "图片ID:".$time;
}
}
catch(Exception $e)
{
echo "ERROR";
}
?>
看到 data:image/s3,"s3://crabby-images/5a785/5a785227fb77197e00cd00e1b1353799fd03789d" alt="在这里插入图片描述"
知道过滤了<? 这样注意写一句话木马的时候要注意双写 data:image/s3,"s3://crabby-images/cf13b/cf13b8f50a30882de0ccd3e81fcc78c30165b8eb" alt="在这里插入图片描述"
还要注意这里文件名被md5加密了 data:image/s3,"s3://crabby-images/2b9d6/2b9d62a343e243340d0af1cbee72b01189a6dbfa" alt="在这里插入图片描述"
上传一句话木马 data:image/s3,"s3://crabby-images/cb46d/cb46df489b79404211aca1c2673d28316fde6249" alt="在这里插入图片描述"
加密的文件名 data:image/s3,"s3://crabby-images/c29cb/c29cb687ea4b0dc862a04616232e7ef76ed49bf7" alt="在这里插入图片描述"
访问
data:image/s3,"s3://crabby-images/80c6d/80c6d4e22bdce9cfd834342d9052f699f62d9fc7" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4ed3d/4ed3dedba0eadf222856f73b50f64c5d65a31e0f" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/dc101/dc10156f2b2af2e2acfc05f78a2d35f4d5e1effd" alt="在这里插入图片描述"
现在链接上后台就行
|