IThome 2024 鐵人賽 一直刷 CTF - Day28
前言
本日進度:
上課紀錄
XOR
data:image/s3,"s3://crabby-images/d29a4/d29a421324246f91ee691e2213dc3207affae90b" alt="Image"
MOD
data:image/s3,"s3://crabby-images/d6d2c/d6d2c7ac03aa86633f044ddd99825d774be4872f" alt="Image"
Lab - XOR wormup
改一下他的程式碼就可以得到 Flag 了1
2
3
4
5
6
7
8
9
10
11from Crypto.Random import get_random_bytes
# from flag import FLAG
FLAG = bytes.fromhex("603ad76575ed41dd3fd38be80d6edfdc569e2a324c928741129e210e2c934aa3770ff8d4f0c5340e82d9c0eea5")
def xor_bytes(a, b):
return bytes(x ^ y for x, y in zip(a, b))
random_data = bytes.fromhex("0209e4030e9929b44c8ce29b5216b0ae09ed456d29f3f4386be7585114f22ec2436ecdb795f2506db0bff5dcd8")
result = xor_bytes(FLAG, random_data)
print({result.decode()})
流密碼
data:image/s3,"s3://crabby-images/c5a10/c5a10732196dc8f589ab804dfaabae0dbb654178" alt="Image"
隨機數
data:image/s3,"s3://crabby-images/57c9a/57c9a97de12f74027acfa971ab9793a4dc6e5069" alt="Image"
偽隨機數
data:image/s3,"s3://crabby-images/362eb/362eb56ccc41b2123ec6bd2f781b97c0bac31e27" alt="Image"
data:image/s3,"s3://crabby-images/51ad5/51ad5fb57133274f9a69b3d5b956e36eef331be7" alt="Image"
線性同餘生成器 (Linear Congruential Generator)
data:image/s3,"s3://crabby-images/784b8/784b81aa91b97414f0a64ac5347af93bcedce655" alt="Image"
data:image/s3,"s3://crabby-images/5609e/5609eed3bf75225db104cccc905ed0d3f0d84709" alt="Image"
data:image/s3,"s3://crabby-images/fbf14/fbf14ede99aa408a12c8b27c8189e1979ed90876" alt="Image"
data:image/s3,"s3://crabby-images/a0020/a0020301c48763dbe14da475166397bbbddfeb3b" alt="Image"
其他常見方法
data:image/s3,"s3://crabby-images/c23f1/c23f135c5c68c8d992d2e3f62f9e65b3ddf8b1a2" alt="Image"
反饋位移生成器 (Feedback Shift Register)
data:image/s3,"s3://crabby-images/d148c/d148cf3ddcb2ced0106676aa9834dd76f2d214d5" alt="Image"
data:image/s3,"s3://crabby-images/4cb8a/4cb8a0332b795a70845ca980c52ddb66bcfd7be5" alt="Image"
lab - eof-almost baby prng
lab - easy lcg
lab - eof lf3r
對稱式加密
data:image/s3,"s3://crabby-images/c2482/c248244c22607ebd69ce289b9e88c67f1fcd1056" alt="Image"
重點是 使用同一把鑰匙
基本策略
- Confusion
- 混淆密文和密鑰的關係,使難以從密文推斷出密鑰
- Defusion
- 改變一點點明文,就能改變很多密文
Feistel Network
data:image/s3,"s3://crabby-images/faf30/faf30be7f22eeda3003f31832f63b2d02cdd13fb" alt="Image"
DES (Data Encryption Standard)
data:image/s3,"s3://crabby-images/8aba6/8aba63c0f9199eb00306f84796a306fce67e40c3" alt="Image"
data:image/s3,"s3://crabby-images/ac8b5/ac8b50c66aff075f4ab5c74ca21f20d1a56f9894" alt="Image"
data:image/s3,"s3://crabby-images/2dca0/2dca01b7c7eb2e0d2748c2aaec6d4bfac1746211" alt="Image"
data:image/s3,"s3://crabby-images/9d4e5/9d4e53aa83de1209055975caeb7c59a3aceff1a3" alt="Image"
Substitution-Permutation Network
data:image/s3,"s3://crabby-images/6055b/6055bf619d16f1afd2cf86985779f888ba881786" alt="Image"
AES (Advanced Encryption Standard)
data:image/s3,"s3://crabby-images/d43be/d43be539f9d723d2f8ba6bb9eb84f46ed856f42e" alt="Image"
data:image/s3,"s3://crabby-images/581aa/581aaea02fdd740922bf3d8f4a79c970fc2590b2" alt="Image"
data:image/s3,"s3://crabby-images/345e9/345e995e1e0e9628e4c2bf5ae5ccd9a2a79f6fd0" alt="Image"
data:image/s3,"s3://crabby-images/6f81a/6f81a618707d6dcf99851b085ccc2ac828136d45" alt="Image"
TODO
之後好好研究一下原理還有把上面三題 lab 做完