NSSCTF [SWPUCTF 2021 新生赛]fakerandom

打开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}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值