本文目录一览:
- 1、各种软件显示的随机数字,是否是真正的随机不可预测,如果是真的随机,是否证明电脑可以自主决定权。
- 2、为什么说Java中的随机数都是伪随机数
- 3、当今的电脑是怎么产生随机数字的,如果是以时间为变量的函数,那他是不是可以预测?
- 4、随机数生成能破解吗果能的话请说明 *** 我说的不是彩票是一个机器他随机出三个数我是否能看前数字判断后出
- 5、为什么采用随机数可避免重放攻击
- 6、网页中出现的随机数能否预测,如果能,如何预测?
各种软件显示的随机数字,是否是真正的随机不可预测,如果是真的随机,是否证明电脑可以自主决定权。
电脑生成的普遍意义上的随机数是根据随机种子和随机算法计算而来的伪随机数,并非真正的随机数,知道种子和随机算法后该随机序列可以计算得到。
为什么说Java中的随机数都是伪随机数
声明下:以下是我复制的,我本人也算是涨知识了.噪声厉害了我的哥!
1.只要是通过算法产生的随机数都是伪随机数。
2.通过真实随机事件取得的随机数才是真随机数。
3.Linux和windows 系统都有自带的真随机数函数,它们是通过外部噪音来实现的,如,敲击键盘的时间间隔,特定的中断等。
4.像编程语言自带的随机数函数是很容易被黑客破解的
5.例如:Java的随机数产生是通过去模运算产生的,黑客只需要知道连续的2个随机数就可以预测下一个随机数。python 采用的是MT算法,破解难度要稍微比Java 难一些!
当今的电脑是怎么产生随机数字的,如果是以时间为变量的函数,那他是不是可以预测?
编程语言里边每次使用随机数的时候 都需要一个种子(seed)这个种子通过某种算法可以生成一系列的伪随机数之所以是伪随机数而非随机数 是因为通过这种算法生成的数列是可知的 与随机的定义不一样如果种子指定了,那么无论调用多少次,生成的伪随机数列总是相同的。一般情况下,随机种子的缺省值为当前系统时间,具体精确度取决于系统和编程语言。对于是否可以预测,这里有 一个例子 。在这个例子中,因为编程语言的原因,造成了随机种子集远小于扑克牌所有可能组合集。并且使用服务器时间作为种子,使得实际扑克牌顺序可猜测。然而一旦随机种子的 *** 够大,或者同时使用数个随机种子,可以大大降低被猜测到的概率。
希望采纳
随机数生成能破解吗果能的话请说明 *** 我说的不是彩票是一个机器他随机出三个数我是否能看前数字判断后出
之一个问题:中国或者国外的黑客有没有破解过彩票摇奖机这个,可以说肯定有;破解者如果破解了彩票摇奖机随机数出数概率,那么一定能中奖 不能说一定,但是
为什么采用随机数可避免重放攻击
单独的随机数不能避免重放攻击,随机数一般会和签名加密技术,后台验证技术混合以提高破解和重放难度。
重放攻击(Replay Attacks)又称重播攻击、回放攻击或新鲜性攻击(Freshness Attacks),是指攻击者发送一个目的主机已接收过的包,来达到欺骗系统的目的,主要用于身份认证过程,破坏认证的正确性。
从重放攻击的定义上我们可以看到,重放攻击提交给服务器的数据是曾经有效的,如何防止这种数据,对特定信息给与一个特定的随机数,并且这个随机数保存在服务器内,在验证了用户信息前,首先会对随机数进行验证,如果发现提交的随机数和服务器保存的不同则,该条信息无效通过这种 *** 来防止重放攻击。
常用的防御重放攻击,不会直接暴露随机数,一般随机数会用在MD5,HASH(数字签名)上,比如在对有效值进行MD5加密时添加随机数,如用户名为test,密码为test的MD5加密过程可能为MD5("test","test",随机数),这样在直接传输时不会暴露出随机值,黑客在提交重放攻击时系统发现MD5签名和系统签名计算后不同则,可被认定为重放攻击。
当然矛和盾是一种存在的,有可能该值刚好又一次的分配给了该用户,可能会重放攻击成功,但这个概率在科学计算上可以被视为0,而且随着随机数的位数的提高,概率会不断降低。
网页中出现的随机数能否预测,如果能,如何预测?
其实是可以的,不过你要知道产生随机数的函数的源代码。随机数也是有规律的,不然它那个函数老输出同一个数怎办