- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我知道如果我们声明:
SecureRandom random=new SecureRandom();
它初始化生成随机数的默认算法是NativePRNG
,它读取/dev/random
来生成真正随机的种子
。现在我们有了真正随机的 seed
,它是 160 位大小,但我很困惑当我们调用 random.nextBytes(bytes);
时会发生什么。它如何从 seed
生成 bytes
,是否再次读取 /dev/random
或其他内容。
谢谢。
注意:我正在寻找 linux/MAC box 中 java 7 的默认行为。
最佳答案
来自 Java API 文档:
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.
因此,nextBytes(bytes)
是否从 /dev/random
返回真正的随机字节,或者它是否返回从真正的随机种子生成的伪随机数取决于。第二种情况意味着使用最初的随机种子,通过对 SecureRandom
的任何调用生成确定性但看似随机(因此是伪随机)的数字序列。
Java 7 允许指定可配置的 PRNG 源,但在 Linux 上默认的是 NativePRNG
而在 Windows 上是 SHA1PRNG
。您也可以在 Linux 上指定 SHA1PRNG
,但默认选项 NativePRNG
更好。 SHA1PRNG
通过使用 SHA1 生成 PRNG 位和字节。在 Linux(可能还有其他 Unixes,机制是“NativePRNG
”)上,算法从 /dev/random
和 /dev/urandom
读取>,只要其中任何一个有足够的熵可用。为了完整起见,来自 random
的 Linux 手册页:
A read from the /dev/urandom device will not block waiting for more entropy. As a result, if there is not sufficient entropy in the entropy pool, the returned values are theoretically vulnerable to a cryptographic attack on the algorithms used by the driver.
因此,至少在 Linux 上,您的 SecureRandom
将具有一定数量的真正随机输出,直到 /dev/random
阻塞,因为熵不足,但是,如果您请求太多随机位,它们最终将开始由底层 /dev/urandom
机制生成,该机制可能使用 SHA1 或其他一些加密哈希算法PRNG.
最好创建一个 SecureRandom
而不要自己指定任何明确的种子,因为它会自己播种(默认情况下通过 /dev/random
和 /dev/urandom
对于 Linux 上的 NativePRNG
)有一个好的种子。每隔几分钟调用一次 nextBytes(bytes)
,即使字节数很大,在几乎任何情况下都不会成为问题。即使您正在使用 NativePRNG
并且它求助于通过 SHA-1 之类的东西从 /dev/urandom
获取伪随机字节,其输出仍然非常难以预测。
如果您要求千兆字节的随机性,最好重新播种,使用 SecureRandom
本身的一些输出或提供您自己的种子。请注意,向 setSeed()
提供任何类型的种子应该是安全的,因为 SecureRandom
通过将您提供的种子和之前的种子提供给类似SHA-1 或其他加密哈希算法。但是,最好在不提供自己的种子的情况下创建初始 SecureRandom
。
关于java - 我们有种子后 random.nextBytes(bytes) 如何生成字节,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21254006/
Sequelize 中有没有办法添加另一列,然后用另一列的内容填充它? 最佳答案 您可以使用迁移来做到这一点。 就像是 queryInterface.addColumn( 'MyAwesomeTa
如何计算info_hash参数?又名对应于信息字典的哈希?? 来自官方规范: info_hash The 20 byte sha1 hash of the bencoded form of the i
是否可以直接从数据库或服务等将 URL 获取到 Nutch。我对从数据库或服务获取数据并将其写入 Seed.txt 的方式不感兴趣. 最佳答案 没有。这不能直接使用默认的 nutch 代码库来完成。需
MessageDigest 类实现了 SHA-1 算法(以及许多其他算法)。 SHA-1 算法允许使用不同的“种子”或初始摘要。参见 SHA-1 Psuedocode 算法初始化变量,或种子: Ini
我想创建一个应用程序,其中登录密码可以作为伪随机数生成器的种子以重新创建加密 key 。然后,该加密 key 将用于加密发送到应用程序数据库和从应用程序数据库发送的所有数据,使用户数据甚至主机都无法访
这个问题在这里已经有了答案: Recommended way to initialize srand? (15 个答案) 关闭 8 年前。 使用 srand(time(NULL))似乎过于确定性。例
我在获取要在我的自定义数据库初始值设定项上调用的 Seed 方法时遇到问题。我正在使用 EF 5.0 并具有以下代码: public static class MyDatabase { pub
是否可以像在 Rails 中那样“播种”数据库?我想将种子与图像对象管理器结合使用,以便我可以按标题获取记录。 最佳答案 根据您对 Ingo 的回答留下的评论,您想将 requireDefaultRe
我现在设置了一个应用程序来使用 EF6 代码优先迁移。我使用 Add-Migration 的标准工作流程,然后在控制台中使用 Update-Database。我在本地以及我们的开发环境中使用 Migr
如果 Name 返回然后删除 first name Name john Age 30 Name Alice Name Travis Age 12 Name Monty Name Hannah 期望的输
在迁移完成后,是否可以在我的迁移中放入一些东西来自动为表播种测试数据? 或者您必须单独播种? 最佳答案 您可以使用 --seed 选项调用 migrate:refresh 以在迁移完成后自动播种: p
我正在尝试使用不同的种子生成 scipy.stats.pareto.rvs(b, loc=0, scale=1, size=1)。 在 numpy 中,我们可以使用 numpy.random.seed
我的种子有问题。这是我的表结构: 1.Complaints: Schema::create('complaints', function (Blueprint $table) {
我在使用数据库初始化程序时遇到问题 - 从未调用过种子方法。类似的代码在另一个项目中工作,所以我很困惑为什么他们这次不工作。 这是我的代码: RecipeContext.cs public c
我正在尝试做一些我认为非常简单的事情,只需使用 RAND 创建 0-1 之间的随机数,并将其分配给十进制变量。但每次我在 MySQL 中运行代码时,它都会返回零! 参见下面的代码: DELIMITER
我有一个问题...... 这里我们得到了一个二维字节数组: byte[][] duengonMap = new byte[500][500]; 因为我想将它从客户端发送到服务器或者相反,我需要将其放入
我尝试在我的计算机上运行 Angular-seed(Windows 10,上次更新)https://github.com/angular/angular-seed 。网络工作正常,但我的 Protra
我有一个随机过程的分布式过程。因此,我使用 numpy.random.RandomState 来播种数字。问题是我必须在包装器中使用另一个 numpy.random 函数。现在我失去了种子的再现性,因
我需要确保我程序中的所有随机性都是完全可复制的。我应该在哪里调用 random.seed()? 我认为它应该在我的 main.py 模块中,但它导入了碰巧使用随机函数的其他模块。 我可以仔细浏览我的导
首先尝试使用 Entity Framework 和代码在 ASP.NET 网络应用程序中植入数据。我将这段代码放在 Configuration.cs 文件的 Seed() 方法中。现在,我正在处理解决
我是一名优秀的程序员,十分优秀!