[SWPUCTF 2021 新生赛]fakerandom

发布时间 2023-05-09 16:35:17作者: TFOREVERY

查个壳:

没得东西:双击进去咯:

随机序列问题:

这里要提几点点:

一:同一个种子下获得的再次获得的随机数是相同的

怎么理解这个呢,上图理解:


能看到我们两次的随机数是完全一样的,但是如果不加random.seed(1)这一句或者将种子换了,就不一定会得到相同的数字了:

二:random.getrandbits()函数的作用:返回一个 8 位大小的整数。

什么叫8位大小的整数?是指有8位数的整数吗?比如12345678?

并非如此,应该是二进制的8位:11111111 --> 也就是255为上限。

理解到这开始做题吧:

emm...又是异或,也没啥加密,那么就可以简单来一脚了:

import random

result1 = [201, 8, 198, 68, 131, 152, 186, 136, 13, 130, 190, 112, 251, 93, 212, 1, 31, 214, 116, 244]
flag1 = ''
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):
        flag1 += chr(result1[i*5+n] ^ random.getrandbits(8))
# result.append(ord(flag[i * 5 + n]) ^ random.getrandbits(8))
print(flag1)

拿到NSSCTF