打开py附件
import random
flag = 'xxxxxxxxxxxxxxxxxxxx' # 待加密的字符串
random.seed(1) # 设置随机数生成器的种子为1,以确保每次生成的随机数序列相同
l = [] # 存储随机数的列表# 生成4个8位随机数并存储在列表l中
for i in range(4):l.append(random.getrandbits(8))result = [] # 存储加密结果的列表# 遍历列表l中的随机数
for i in range(len(l)):random.seed(l[i]) # 使用l[i]作为种子重新设置随机数生成器# 对flag字符串进行加密for n in range(5):# 将flag字符串中的字符转换为ASCII码,与生成的8位随机数进行异或,并将结果存储在result列表中result.append(ord(flag[i*5+n]) ^ random.getrandbits(8))# 打印加密结果
print(result)
解密脚本
- 按照每个包含5个元素的块迭代加密的
result
列表。 - 对于每个块:
- 使用
result
列表中对应的值对随机数生成器进行初始化。 - 将该块中的每个元素与使用
random.getrandbits(8)
生成的随机字节进行异或操作。 - 将解密后的字符附加到字符串中。
- 使用
import random
flag = ''
random.seed(1)#产生种子1对应的序列。
l = []
for i in range(4):l.append(random.getrandbits(8))#random.getrandbits(8)输出一个0~2^8-1范围内的一个随机整数,8表示的是2进制的位数
result=[201, 8, 198, 68, 131, 152, 186, 136, 13, 130, 190, 112, 251, 93, 212, 1, 31, 214, 116, 244]
for i in range(len(l)):random.seed(l[i])for n in range(5):flag+= chr(result[i*5+n]^random.getrandbits(8))
print(flag)
得到flag
NSSCTF{FakeE_random}