java 实现真正的随机数_关于java:SecureRandom的Android实现是否产生真正的随机数?...

我已经阅读过,一般来说,SecureRandom的一些实现可能会产生真正的随机数。

特别是,Android文档说

instances of this class will generate an initial seed using an internal entropy source, such as /dev/urandom

但这是否意味着它将产生真正的随机数(即,而不是伪随机数)?

如果我用这种方式在Android中使用SecureRandom…

…当我调用sr.nextBoolean()时,会得到一个真正的随机输出吗?

或者产出可能更多(或更少?)随机,如果我每次都通过这样做获得输出:江户十一〔二〕号?

这不一定是真的,因为有些Android设备没有硬件来生成真正的随机数。至于具有该硬件的设备是否会使用它,我不这么认为,尽管Linux内核可能会加载一个模块,从该硬件获取真正的随机数。

afaik所有实现都使用不同的形式或算法散列。虽然它们具有良好的数学性质,但并非真正的随机性。

从Android开发人员的博客中,"我们已经确定,使用Java加密体系结构(JCA)来进行密钥生成、签名或随机数生成的应用程序可能不会因为底层PRNG初始化不当而在Android设备上获得密码强大的值……"。之后,我相信AOSP会切换到OpenSSL的生成器。变化发生在果冻豆上。

@我有代码可以使用JNI读取Android的传感器,然后输入一个随机数生成器(比如OpenSSL或Crypto++)。您可以使用它来做同样的事情,或者使用它来生成Java HMAC/SHA-1生成器。"肉和土豆"源文件位于android/crypto++prng的Pastebin上,由传感器自动播种(由jww提供)。我希望尽快将Eclipse项目上传到Crypto++wiki(wiki目前因配置更改而出现问题)。

坚持。/dev/urandom仅用于生成初始种子。在那之后,一切都是算法。SecureRandom需要"提供加密强随机数生成器(RNG)"。

"真"和"伪随机"随机数对不同的人来说意味着很多不同的事情。最好避免这些。

/dev/urandom的代表性很差,因为人们不理解它和/dev/random之间的区别(比你想象的要差很多,少得多)。

如果你问/dev/urandom的种子植入是否会损害SecureRandom用于加密目的的适合性,答案是响亮的"不"。

如果你有时间的话,你可能会想读我关于整个问题的文章。

你好,托马斯,我想你有一个打字错误-一个铀之国的。(而且,不,这不是为了加密目的。)

根据Android开发者文档:

(SecureRandom) complies with the statistical random number generator tests specified in FIPS 140-2, Security Requirements for Cryptographic Modules, section 4.9.1

然而,同样的警告也适用于Android,就像Java一样:

Many SecureRandom implementations are in the form of a pseudo-random number generator (PRNG), which means they use a deterministic algorithm to produce a pseudo-random sequence from a true random seed. Other implementations may produce true random numbers, and yet others may use a combination of both techniques.

因此,简短的回答是:这取决于实现,但是如果您对FIPS 140-2满意,那么SecureRandom就足以满足您的目的了。

关键的答案是,由Linux内核定义的/dev/urandom保证不会阻塞。重点是在产生足够的熵的同时不拖延用户。如果Android文档说他们正在使用/dev/urandom进行初始化,并且内核中没有足够的熵来提供随机数,那么内核将返回到伪随机算法。

根据内核文档,除了"长寿命[加密]密钥",/dev/urandom几乎可以用于所有目的。考虑到您的预期用途,我怀疑Android SecureRandom将证明足够随机用于您的目的。

Android是一种独特的野兽。它有/dev/urandom,但我不相信android的SecureRandom和SecureRandomSpi在使用它。相反,种子确实很弱——它本质上是系统属性(比如序列号、基带版本)、时间(毫秒和纳秒)和字符串"你的随机性都属于我们"。查看entropyService.java。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值