[SWPUCTF 2021 新生赛]fakerandom 关于random.seed的一些事
最近开始接触reverse了,难得有些力不从心(本质还是汇编看不懂),来看看这道题吧。
点击查看代码
import random
flag = 'xxxxxxxxxxxxxxxxxxxx'
random.seed(1)
l = []
for i in range(4):
l.append(random.getrandbits(8))
result=[]
for i in range(len(l)):
random.seed(l[i])
for n in range(5):
result.append(ord(flag[i*5+n])^random.getrandbits(8))
print(result)
# result = [201, 8, 198, 68, 131, 152, 186, 136, 13, 130, 190, 112, 251, 93, 212, 1, 31, 214, 116, 244]
可以看到seed相同的时候生成的随机数是相同的,那么这个很蠢的问题就迎刃而解了。
第一次l就是固定的random[34, 145, 216, 205]。
而下一个循环里的random分别为:
l[1][135, 91, 149, 7, 215]
l[2][222, 193, 206, 108, 233]
l[3][219, 53, 164, 47, 181]
l[4][111, 123, 185, 25, 137]
这样NSSCTF不就出来了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通