[SWPUCTF 2021 新生赛]fakerandom
查个壳:
没得东西:双击进去咯:
随机序列问题:
这里要提几点点:
一:同一个种子下获得的再次获得的随机数是相同的
怎么理解这个呢,上图理解:
能看到我们两次的随机数是完全一样的,但是如果不加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)