Даже после нескольких статей, посвященных SecureRandom
, я столкнулся с сомнением в использовании SecureRandom
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
, поскольку он почти дает тот же результат.
Может ли кто-нибудь сообщить мне, если я поступаю правильно здесь?