CTF_Web_WriteUp
南邮CTF web write up, 题目是按分数从少到多顺序排列,后续有新的体会会更新
签到题
data:image/s3,"s3://crabby-images/747de/747deaa077c6838860ae9a18b84a20d513cd05d7" alt=""
data:image/s3,"s3://crabby-images/88104/88104352c306ffecb46c89b536042dd4446faea1" alt=""
签到二
右键查看代码:
data:image/s3,"s3://crabby-images/985f7/985f7534d9c4523d29c63a17676bc13a90efbe34" alt=""
可以看到输入框里面对最大长度做了限制,改一下maxlength,输入口令得到flag:
data:image/s3,"s3://crabby-images/70e6b/70e6b147d25d1939c55e112d4dd24181d65d87b1" alt=""
md5 collision
解释题目: md5碰撞 emmm... 好的看代码,已经给了一个字符串了,那就...
data:image/s3,"s3://crabby-images/c50d3/c50d3337c8ee50902bdd347b6e9c5721ed0cf0ea" alt=""
data:image/s3,"s3://crabby-images/006d3/006d3f578e822bae14ff706d50fa819a736e8d43" alt=""
将a的值代入得到flag:
data:image/s3,"s3://crabby-images/8991f/8991f6b9bbef6ce193d1d3a7160b0b6f983eb98e" alt=""
单身二十年
data:image/s3,"s3://crabby-images/e4f08/e4f0885849c31a0a32758e71d486a3bb431ea5fc" alt=""
点击之后,如下:
data:image/s3,"s3://crabby-images/2d7b6/2d7b6505feae0bade574131125b11ff7bd82c547" alt=""
怎么办呢?burpsuite抓个包?当然可以。
有不用安装软件就能抓包的吗?当然也有,浏览器是无敌的。
让我们打开“开发者工具”——“network”——勾选“Preserve log”,再重新回到web8,点击”到这里找key“
data:image/s3,"s3://crabby-images/b490f/b490fde269a6bfa674053741047c1ea18269d52c" alt=""
点击,查看response。
data:image/s3,"s3://crabby-images/4e922/4e922800b20b4f7c503d9e727928fe777bd95e39" alt=""
竟然没有,但是没关系,浏览器是无敌的。让我们来强行查看网页源码
data:image/s3,"s3://crabby-images/510f5/510f501a85a8548227fbd75e521a5857e88b1cda" alt=""
tips:view-source://website/target.php
这题不是WEB
data:image/s3,"s3://crabby-images/d10d0/d10d0e7d9702c4e3e71686eb6a7c128452fc05c6" alt=""
存图,用VS Code打开,启动hexdump
data:image/s3,"s3://crabby-images/8e790/8e790536ed2da47d3afb7c15dc46921335014628" alt=""
层层递进
打开,是一个电商网站,查看源码发现有很多文件,打开看看
data:image/s3,"s3://crabby-images/2244d/2244dd3f198cd26755dc47160f16cbfbabcbbd3b" alt=""
层层打开,最后是一个404文件,打开如下,注释出现flag(竖着看)
data:image/s3,"s3://crabby-images/fc7d2/fc7d29311812abb217d60d79041755bacc9a8a6c" alt=""
文件包含
没错,这就是传说中的LFI (php文件包含漏洞)
伪协议读取文件,拿到以下字符串
data:image/s3,"s3://crabby-images/4e12e/4e12ea803bb0059aa156ece1a7007ce6c3dcffe5" alt=""
base64在线解密
data:image/s3,"s3://crabby-images/c693b/c693bbd3ea24a758e151bce20ed0ad240c73fe5c" alt=""
COOKIE
题目提示:0==not
那么我们就猜想 1==true, cookie里面也许有0,把它改成1就可以。右键查看源码
果然 cookie如下
data:image/s3,"s3://crabby-images/f7b56/f7b56b3f11d3f1368afc10b3392136bfa0c40a4e" alt=""
尝试将login改成1,刷新拿到flag
data:image/s3,"s3://crabby-images/c7f7b/c7f7bcf892dd53f400208fc57f854ca5308f88d8" alt=""
单身一百年也没用
打开网址 点击“到这里找key” 网页跳转了
data:image/s3,"s3://crabby-images/d42bd/d42bd455595aee2653ff2af7d271578a46b31604" alt=""
查看原网页的源码,跟单身二十年一样的套路
data:image/s3,"s3://crabby-images/d2fbd/d2fbd139172c549ef3324cdc8c6276d08b1ab0eb" alt=""
那就让我们继续骚操作,跟着我一起view-source://。。。/index.php
data:image/s3,"s3://crabby-images/dd600/dd6004adc1d9bd675db392897ea574a4fc3b31f2" alt=""
还是跳转了???斯国以
data:image/s3,"s3://crabby-images/e72d2/e72d224d159f3ec4b0b3f8c80ddb76d6e013bd3a" alt=""
没事上面不是还有另外一种方法吗?让我们打开google浏览器的检查,勾选Preserve log 刷新,拿到了
data:image/s3,"s3://crabby-images/35019/35019d8a6fcfcb739fbee91495367d9c2bf47f78" alt=""
查看一下相应的结果
data:image/s3,"s3://crabby-images/e6cd6/e6cd61ae986d418f61b70dc7bd696304083f373f" alt=""
不要放弃,再看看头,头里面也许有信息呢
data:image/s3,"s3://crabby-images/596e9/596e9fbbaf8e78dd58400b7e0e0737f68676ba5a" alt=""
在相应的消息头里面出现了flag,Crtl+C Crtl+V 提交
php decode
data:image/s3,"s3://crabby-images/b8a51/b8a517b4abd8358728076a01cd77a0f18f22fd29" alt=""
PHPStorm跑起来(在线网页也可以
data:image/s3,"s3://crabby-images/ed0c9/ed0c9c0a81b97fd145055da0cbffa4aa271f818d" alt=""
将eval改成echo,拿到flag
data:image/s3,"s3://crabby-images/d0f00/d0f00d64a88d843d1f40dbfd4ed5b0932408ff91" alt=""
bypass again
提示php弱类型,源码如下:
if (isset($_GET['a']) and isset($_GET['b'])) {
if ($_GET['a'] != $_GET['b'])
if (md5($_GET['a']) == md5($_GET['b']))
die('Flag: '.$flag);
else
print 'Wrong.';
}
构造md5数组如下,拿到flag:
data:image/s3,"s3://crabby-images/5b094/5b0946ddf3c8760a9c7fca6e6852ecd0097c4454" alt=""
MYSQL
打开网址,提示robot.txt
data:image/s3,"s3://crabby-images/98766/98766f557ee09f80ef61ce6a78fce488facbd9eb" alt=""
划重点 sql.php 当id=1024,显示no!try again
data:image/s3,"s3://crabby-images/e53a2/e53a2c68bbfcce3b7772eb179dad99fd69c87a5f" alt=""
尝试打开sql.php
data:image/s3,"s3://crabby-images/dcb13/dcb137260e8d3d0e63ddc74023d267e55c426106" alt=""
再试试别的id
data:image/s3,"s3://crabby-images/a7d41/a7d418ee64b40f8442c886431fc2836085cb4586" alt=""
data:image/s3,"s3://crabby-images/d2288/d2288651ea2c367d572b0c04c9f43ca47bc93284" alt=""
data:image/s3,"s3://crabby-images/4d2a0/4d2a0b8d00145cc54d6959604f975612bbf92f26" alt=""
尝试一下浮点数
data:image/s3,"s3://crabby-images/1a10d/1a10da0404514b79626547af957a3fce6d66e582" alt=""
/x00
打开,页面如下:
data:image/s3,"s3://crabby-images/d5069/d50697887796ea9cc06941be5ed12330d0cc86c7" alt=""
查找strpos用法
data:image/s3,"s3://crabby-images/683ab/683abe37777ebe72bb85a506919543d1bfb1db0d" alt=""
data:image/s3,"s3://crabby-images/a526a/a526a2a2d256d80128b3c3da911401b0db740611" alt=""
可知当变量nctf里面的字符串包含biubiubiu,能拿到flag。
尝试 nctf[] = biubiubiu
data:image/s3,"s3://crabby-images/7ebd8/7ebd84c00eaf3258ddadb5be83686c694cf49d15" alt=""
SQL注入1
常规操作 检查源码
data:image/s3,"s3://crabby-images/13cf1/13cf1fdcd54180c563ed68b775dcf577634077a8" alt=""
打开如下,分析代码可知只有当user是admin时才能拿到flag
data:image/s3,"s3://crabby-images/30a75/30a7522b6fbbab911f42194c72a701cff4cb563d" alt=""
将user改为admin提交
data:image/s3,"s3://crabby-images/7515e/7515e29a3519c4bcc5f312fb5f86f188cb252709" alt=""
重新看代码,变量sql有选择password,把password注释掉, 构造如下
data:image/s3,"s3://crabby-images/873df/873df12214ca2429743afed808d3c631e147ca10" alt=""
拿到flag
data:image/s3,"s3://crabby-images/ec602/ec602ad2e8b0ec6a92b98744ac4c2f0b312daa84" alt=""
SQL注入2
查看source里面的内容
data:image/s3,"s3://crabby-images/e55d7/e55d7614b18b5153fc6731cef2d8485cd2aff90c" alt=""
分析代码,找到注入点,首先username和密码都不能为空,strcasecmp用法:
strcasecmp——比较两个字符串(不区分大小写)
<?php echo strcasecmp("shanghai","SHANGHAI"); ?>
找到显示flag条件
data:image/s3,"s3://crabby-images/20157/20157de152b2d04ea4514fcc490abdfb339c51d3" alt=""
尝试union查询,username:username' union select md5(1)# password:1
拿到flag
data:image/s3,"s3://crabby-images/2fb24/2fb2401dbc07167ff4b6492313c4ca45a9fd4ca6" alt=""
data:image/s3,"s3://crabby-images/14fb9/14fb9dc3fe8b9fc13a64aaaf4ceab25f20f84c0f" alt=""