Java提供了两个用于生成随机数的类-SecureRandom.java和Random.java。随机数通常可用于Web服务器上的加密键或会话键或简单地用作密码.SecureRandom在java.security软件包下,而Random.java则在两者之间的基本和重要区别在于,与使用线性同余生成器(LCG)的Random类相比,SecureRandom实现了加密安全的伪随机数生成器(CSPRNG),因此生成了更多不可预测的随机数。
这里要提到的重要一点是SecureRandom是Random类的子类,并继承其所有方法,例如nextBoolean()
,nextDouble(),nextFloat(),nextGaussian(),nextInt()和nextLong()
。
Random和SecureRandom之间的其他区别包括-
随机类使用系统时间作为其生成算法的输入,而SecureRandom类使用操作系统的随机数据(例如I / O事件的计时)。
由于在SecureRandom情况下使用了复杂的算法,这使其变得更加不可预测,因此在创建安全随机数时要比在随机数上花费更多的内存。
随机类只有48位,其中SecureRandom最多可以有128位,这使得在SecureRandom中重复的可能性更小,因此打破随机数预测的尝试次数为2 ^ 48,而SecureRandom数为2 ^ 128再次使其更加安全。
import java.util.Random; public class RandomClass { public static void main(String args[]) { Random objRandom = new Random(); int randomInt1 = objRandom.nextInt(1000);//1000 is range i.e number to be generated would be between 0 and 1000. int randonInt2 = objRandom.nextInt(1000); System.out.println("Random Integers: " + randomInt1); System.out.println("Random Integers: " + randonInt2); } }
输出结果
Random Integers: 459 Random Integers: 348
import java.security.SecureRandom; public class SecureRandomClass { public static void main(String args[]) { SecureRandom objSecureRandom = new SecureRandom(); int randomInt1 = objSecureRandom.nextInt(1000); int randonInt2 = objSecureRandom.nextInt(1000); System.out.println("Random Integers: " + randomInt1); System.out.println("Random Integers: " + randonInt2); } }
输出结果
Random Integers: 983 Random Integers: 579