python随机数的重现

random随机数的重现

因为“随机数”的产生式需要量子计算机(量子就纠缠),所以在python中会使用random来产生伪随机数。

使用random模块生成的随机数是可以被重现的,要实现对伪随机数的攻击,那么就要拿到它的种子。

原理

1.在默认情况下是使用当前操作系统的时间来作为随机数的“种子”

2.可以使用getstate这个函数来获取随机数的种子加工之后,随机数生成器的内部状态

random.getstate()

3.使用变量将随机数的种子进行打印

x = random.getstate
print(x)

4.使用random.randint来生成随机数

random.randint(1,10)

怎末对他进行攻击?

1.现在调用setstate函数重新设置随机数生成器的内部状态

random.setstate(x)
random.randint(1,10)

之后就完成了随机数的重现

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

终会为一

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值