之前学习的Random工具类只是一个伪随机数类。。。
@Test public void secureRandom() throws Exception { // 个不可预测的安全的随机数 // 无法指定种子,它使用RNG(random number generator)算法 // 实际上有多种不同的底层实现,有的使用安全随机种子加上伪随机数算法来产生安 // SecureRandom常用工具类构建全的随机数,有的使用真正的随机数生成器。实际使用的时候,可以优先获取高强度的安全随机数生成器,如果没有提供,再使用普通等级的安全随机数生成器 // 实例获取 SecureRandom secureRandom = new SecureRandom(); // jdk8 获取更安全的实例 SecureRandom instanceStrong = SecureRandom.getInstanceStrong(); String algorithm = secureRandom.getAlgorithm(); Provider provider = secureRandom.getProvider(); String providerInfo = provider.getInfo(); System.out.println("normalInstance algorithm -> " + algorithm + " provider -> " + providerInfo); System.out.println("- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -"); algorithm = instanceStrong.getAlgorithm(); provider = instanceStrong.getProvider(); providerInfo = provider.getInfo(); System.out.println("strongInstance algorithm -> " + algorithm + " provider -> " + providerInfo); }
打印结果:
normalInstance algorithm -> SHA1PRNG provider -> SUN (DSA key/parameter generation; DSA signing; SHA-1, MD5 digests; SecureRandom; X.509 certificates; JKS & DKS keystores; PKIX CertPathValidator; PKIX CertPathBuilder; LDAP, Collection CertStores, JavaPolicy Policy; JavaLoginConfig Configuration) - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - strongInstance algorithm -> Windows-PRNG provider -> Sun's Microsoft Crypto API provider Process finished with exit code 0
获取随机数实例和Random类实例是一样的。