Несмотря на то, что я прочитал много статей о SecureRandom
, я столкнулся с сомнением в использовании SecureRandom
Security API в Java. В приведенном ниже примере.
public class SecureRandomNumber {
public static void main(String[] args) throws NoSuchAlgorithmException {
TreeSet<Integer> secure = new TreeSet<Integer>();
TreeSet<Integer> unSecure = new TreeSet<Integer>();
SecureRandom sr = new SecureRandom();
byte[] sbuf = sr.generateSeed(8);
ByteBuffer bb = ByteBuffer.wrap(sbuf);
long d = bb.getLong();
sr.setSeed(d);
Random r = new Random();
r.setSeed(System.nanoTime());
for (int k = 0; k < 99999; k++) {
int i = sr.nextInt();
if (!secure.add(i)) {
System.out.println("Repeated Secure Random Number");
} else {
// System.out.println("************Unique***********");
}
int j = r.nextInt();
if (!unSecure.add(j)) {
System.out.println("Repeated UnSecure Random Number");
}
}
}
}
Когда я запускаю эту программу, я не нахожу никаких дополнительных преимуществ от использования SecureRandom
, так как это дает почти тот же результат.
Кто-нибудь может дать мне знать, правильно ли я поступаю?