java securerandom使用,播种java.security.SecureRandom是不必要的?

I am using Java 1.7 and as the code below demonstrates (compiled with Oracle's Java 7 compiler in Ubuntu) seeding java.security.SecureRandom appears to be unneccessary as the code produces two different BigIntegers for the starting value of the two pseudo-random sequences:

import java.security.SecureRandom;

import java.math.BigInteger;

public class SessionIdTest {

public static void main (String args[]) {

long seed = System.currentTimeMillis();

{

SecureRandom random = new SecureRandom();

random.setSeed(seed);

BigInteger a = new BigInteger(130, random);

System.out.println(a);

}

{

SecureRandom random = new SecureRandom();

random.setSeed(seed);

BigInteger a = new BigInteger(130, random);

System.out.println(a);

}

}

}

What's the purpose of setSeed then? Or is SecureRandom also using, in addition to the seed, some other source of randomness?

解决方案

The javadoc says:

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.

So, counting on a secure random to generate a deterministic sequence of values by seeding it won't necessarily work, as documented.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值