问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
2022 网刃杯 WriteUp
CTF
同时打MRCTF、pwnhub、网刃杯,属实是遭不住....
0x01 Re ======= freestyle --------- 签到题, data:image/s3,"s3://crabby-images/c73f4/c73f479c309efbaa2fddcf287c52c29263120023" alt="f3250a37261b0acdeb7139d3a8ec33d.png" data:image/s3,"s3://crabby-images/31645/316457eaa79257d0694b28878b36170c1cf54ef9" alt="a60b06730a4015087b45e634bce4b3c.png" data:image/s3,"s3://crabby-images/2b324/2b324015528bca99fee0585f6bc5b5a0de65f2b0" alt="5268e9a9b01481fd8b48b60b13cbda9.png" 解出来两个方程式,第一个为3327、第二个为105 flag{31a364d51abd0c8304106c16779d83b1} Re\_function ------------ 有两个文件,一个是32为exe,另一个是64为的elf文件 exe文件直接看c伪代码没看懂感觉好乱看不懂,我还是直接看汇编吧,相对之下比较友好哈哈哈。 然后经过一整调试发现,是将我们输入的奇数位与0x37异或然后得到了一串字符 data:image/s3,"s3://crabby-images/b5ba4/b5ba434fbf4d9f79edc05b0710ba296735185d57" alt="image.png" 然后看elf文件 是一个base64算法,是经过了魔改的,敲,只换了字符串表然后解接就好了 ```php # coding:utf-8 #s = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" #s = "vwxrstuopq34567ABCDEFGHIJyz012PQRSTKLMNOZabcdUVWXYefghijklmn89+/" s = "FeVYKw6a0lDIOsnZQ5EAf2MvjS1GUiLWPTtH4JqRgu3dbC8hrcNo9/mxzpXBky7+" def My_base64_encode(inputs): # 将字符串转化为2进制 bin_str = [] for i in inputs: x = str(bin(ord(i))).replace('0b', '') bin_str.append('{:0>8}'.format(x)) #print(bin_str) # 输出的字符串 outputs = "" # 不够三倍数,需补齐的次数 nums = 0 while bin_str: #每次取三个字符的二进制 temp_list = bin_str[:3] if(len(temp_list) != 3): nums = 3 - len(temp_list) while len(temp_list) < 3: temp_list += ['0' * 8] temp_str = "".join(temp_list) #print(temp_str) # 将三个8字节的二进制转换为4个十进制 temp_str_list = [] for i in range(0,4): temp_str_list.append(int(temp_str[i*6:(i+1)*6],2)) #print(temp_str_list) if nums: temp_str_list = temp_str_list[0:4 - nums] for i in temp_str_list: outputs += s[i] bin_str = bin_str[3:] outputs += nums * '=' print("Encrypted String:\n%s "%outputs) def My_base64_decode(inputs): # 将字符串转化为2进制 bin_str = [] for i in inputs: if i != '=': x = str(bin(s.index(i))).replace('0b', '') bin_str.append('{:0>6}'.format(x)) #print(bin_str) # 输出的字符串 outputs = "" nums = inputs.count('=') while bin_str: temp_list = bin_str[:4] temp_str = "".join(temp_list) #print(temp_str) # 补足8位字节 if(len(temp_str) % 8 != 0): temp_str = temp_str[0:-1 * nums * 2] # 将四个6字节的二进制转换为三个字符 for i in range(0,int(len(temp_str) / 8)): outputs += chr(int(temp_str[i*8:(i+1)*8],2)) bin_str = bin_str[4:] print("Decrypted String:\n%s "%outputs) print() print(" *************************************") print(" * (1)encode (2)decode *") print(" *************************************") print() num = input("Please select the operation you want to perform:\n") if(num == "1"): input_str = input("Please enter a string that needs to be encrypted: \n") My_base64_encode(input_str) else: input_str = input("Please enter a string that needs to be decrypted: \n") My_base64_decode(input_str) ``` 出了 flag{we1come\_t0\_wrb} ez\_algorithm ------------- 是个比较复杂的,但是是可以爆破的,每一位都和动调时的相同,这样就爆出了,算是个非预期吧 data:image/s3,"s3://crabby-images/81e22/81e22dfebda6d0ea3039a62065ac01865f17dff6" alt="image.png" 这是调整之后的 data:image/s3,"s3://crabby-images/06b2c/06b2c13545a0f1002d9442463c8173194ea28611" alt="image.png" 我们发现与加密后的密文相比第一个字母相同,所以就是w 一次类推爆破出 flag{w3Lc0mE\_t0\_3NcrYPti0N:} 0x02 MISC ========= 玩坏的winxp -------- 火眼仿真,在桌面文件夹取消隐藏,能出来一个图 data:image/s3,"s3://crabby-images/ef531/ef5312bbae331e1d9a43cd985d91fda2fd978e98" alt="image-20220424160152443" data:image/s3,"s3://crabby-images/639df/639dfb3a0d4e42bf49212ec309821c6fb3cc4f60" alt="image-20220424160239701" binwalk,出来一个假flag图,再binwalk,出来加密压缩包 data:image/s3,"s3://crabby-images/0e26d/0e26d119f35447d8f6415676a741883b9d97fd0f" alt="image-20220424160308107" 压缩包注释有提示 data:image/s3,"s3://crabby-images/92a03/92a0387be6d72be5f79e895c6a852e11264cce72" alt="image-20220424160330399" 需要社工,打开取证大师,在浏览器记录发现qq号 data:image/s3,"s3://crabby-images/fa0ec/fa0ec48058b837151056e48e031eceef04b22105" alt="image-20220424160455717" data:image/s3,"s3://crabby-images/cbd2d/cbd2de65902e780559ec65d423872b849338cf22" alt="image-20220424160556541" data:image/s3,"s3://crabby-images/06587/06587d3f8ed88f1b93c2f80b46136a02053b10cb" alt="image-20220424160610740" 解压压缩包,得到flag data:image/s3,"s3://crabby-images/ae810/ae810f7b19720f624ac85a28234a22d354b7bcc8" alt="image-20220424160640462" 0x03 ICS ======== easyiec ------- 一翻就翻到了 data:image/s3,"s3://crabby-images/b007c/b007cfb00386e0b61257b5e4468b7940edf4914e" alt="image-20220424192418622" Carefulguy ---------- 66 f的16进制 data:image/s3,"s3://crabby-images/14656/14656fdd86854a394b7e2a337aca06ce6166a646" alt="image-20220424191931279" 往后翻翻,拼起来 data:image/s3,"s3://crabby-images/fda47/fda47bcbcf16e4757d898773595510d1a552ffa1" alt="image-20220424192036730" ncsubj ------ 找到三段疑似Base64字符串 data:image/s3,"s3://crabby-images/2cbd6/2cbd6a95aaa0423360134783a6db7e23f53ec994" alt="image.png" 拼起来 `anx1fG58Z3xufGF8cHxmfGh8b3x3fHJ8cHxnfA==` data:image/s3,"s3://crabby-images/8741a/8741a3c2a4c831b5eea79246022008d87840b143" alt="image.png" 还有一层 data:image/s3,"s3://crabby-images/ef255/ef2559ac1fa478f1c096caebd7d757da4e8c417a" alt="image.png" 喜欢移动的黑客 ------- data:image/s3,"s3://crabby-images/1b885/1b885f5f40b927ca644f2116855f183635ead5b6" alt="image-20220424155014478" 问转速,参考这个:[https://blog.csdn.net/qq\_43264813/article/details/120262405?spm=1001.2014.3001.5501](https://blog.csdn.net/qq_43264813/article/details/120262405?spm=1001.2014.3001.5501) 在modbus协议中搜UINT16 搜到9933,对应的是26cd data:image/s3,"s3://crabby-images/62f52/62f52dcb6c23b78506386081374a6a37af8fb0ef" alt="image-20220424155226918" 还没到10000,往前找找,找到一个DATA:2766,对应是10086,所以确定是这个,但是68456和68158里都是10086,不确定是哪个 data:image/s3,"s3://crabby-images/3f349/3f349dd92075ab6b0263f0af67cc5c533efdcd24" alt="image-20220424155407186" 所以列了一下,16进制和10进制挨个试,最后好像有个‘+’,记不清了 data:image/s3,"s3://crabby-images/fc097/fc0974f9b1a839070ca6267735f591454f6e6dc9" alt="image-20220424155319789" xyp07 ----- 这题是复现的,无语了,真就找flag大赛 data:image/s3,"s3://crabby-images/6569c/6569cf4e11f7f07a684585c387b40e6eb1baf01f" alt="image.png" data:image/s3,"s3://crabby-images/778b2/778b20ff5523ee15edb3562f1ac294a531e3c5a1" alt="image.png" 0x04 Web ======== sign in ------- 进入后可以看到源码 <?php highlight\_file(\_\_FILE\_\_); $ch \\= curl\_init(); curl\_setopt($ch, CURLOPT\_URL, $\_GET\['url'\]); curl\_setopt($ch, CURLOPT\_HEADER, 0); curl\_exec($ch); curl\_close($ch); ?> 显然 SSRF,可以读文件 data:image/s3,"s3://crabby-images/9c6e1/9c6e14bd2dc13ce11f5b7ab7c8a110a2cc63cb84" alt="image.png" 在 /etc/hosts 中发现内网 ip data:image/s3,"s3://crabby-images/74740/74740b3d5aae84e77756ff5e6ec61b13084860df" alt="image.png" 尝试用 dict 爆破端口,发现只开启了 80 端口,只好去爆破内网网段,在 172.73.26.100 处发现存活主机 data:image/s3,"s3://crabby-images/90426/904265d02d086428df6df264154969e519d516bc" alt="image.png" data:image/s3,"s3://crabby-images/0c704/0c7048f58dd1d5dbc42ec06894ee1975679df8e4" alt="image.png" data:image/s3,"s3://crabby-images/d85a4/d85a479a35aa10119ac0f5cb9fc189a15ca5352b" alt="image.png" 接下来就是一系列的套娃,GET,POST,加 XFF 头,加 Referer 头即可 data:image/s3,"s3://crabby-images/cde62/cde626fa6b402246081d42092963cfe65a771964" alt="image.png" 签到 upload ------ data:image/s3,"s3://crabby-images/f4c3c/f4c3cc1f0ab9ab7be939c39ed8b65e5e8e72238c" alt="image.png" 在题目描述中可以获得提示,在测试后可以发现存在报错注入 data:image/s3,"s3://crabby-images/aedc1/aedc1e7a0f7974207ca2aed5af57c81c3524a271" alt="image.png" 为 10.0.38-MariaDB 数据库与 ubuntu 系统,中间遇到了一些问题,会对`.`进行识别,导致我们不能读取表名,盲猜一手 flag data:image/s3,"s3://crabby-images/4235f/4235f7a3acace445f494168d7f656dc1919f9f96" alt="image.png" `flag{5937a0b90b5966939cccd369291c68aa}` 不够长,MID截取不了 data:image/s3,"s3://crabby-images/db761/db761caf59eceb478e8a5d554247d0b484e27329" alt="image.png" ez-java ------- 进入后为如下页面 data:image/s3,"s3://crabby-images/54b69/54b69bab03328490a1607ff65736d4cc8e553904" alt="image.png" 存在 /download 路由,推测存在任意文件下载 data:image/s3,"s3://crabby-images/62bea/62bea8e1d742794a9f0a0fbec6b52de046ddfc53" alt="image.png" 读取到 web.xml ,发现 /test388 路由,尝试读取对应的包 data:image/s3,"s3://crabby-images/07e48/07e485e8e9f7a643c77f96b32891c73cc5941679" alt="image.png" 反编译后可以看到 data:image/s3,"s3://crabby-images/c5fae/c5fae3e01de088475dd15ab70c814f3b8fb885d7" alt="image.png" 猜测存在 SpEL 注入,不过存在黑名单 data:image/s3,"s3://crabby-images/4781a/4781a61900564e73e94754acf6d92c705c66137f" alt="image.png" 在网上找一下绕过的姿势 data:image/s3,"s3://crabby-images/1875a/1875aed4a55b3ce1494db891cfe78d0c93c72de4" alt="image.png" data:image/s3,"s3://crabby-images/fef1c/fef1c921d25cd20a88013351f664ff50cd34454a" alt="image.png" ```php {new java.util.Scanner(new ProcessBuilder("ls","/").start().getInputStream(), "GBK").useDelimiter("whoami").next()} ``` 0x05 参考文章 ========= <https://www.cnblogs.com/bitterz/archive/2021/08/30/15206255.html#spel%E5%8F%98%E5%BD%A2%E5%92%8Cbypass%E7%9A%84tips> ezjs ---- data:image/s3,"s3://crabby-images/1cb67/1cb67a83e108d959d7078cbed28547d377c197b7" alt="image.png" data:image/s3,"s3://crabby-images/cfc49/cfc492019079ce75fe56813047ec2c4b72337b36" alt="image.png" 原型链污染后利用 wget 读 flag
发表于 2022-04-26 14:08:05
阅读 ( 6290 )
分类:
其他
0 推荐
收藏
0 条评论
请先
登录
后评论
mon0dy
12 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!