当前位置: 移动技术网 > IT编程>开发语言>c# > 【C#】比较 Random 与 RandomNumberGenerator 生成随机字符串

【C#】比较 Random 与 RandomNumberGenerator 生成随机字符串

2020年04月02日  | 移动技术网IT编程  | 我要评论

生成随机数,第一反应肯定是 random 类,然而,random 生成的随机数被称为伪随机数,因为用 random 生成随机数时,需要用到一个“种子”,而 使用相同的种子,一定会产生相同序列的数字

random r1 = new random(1);
console.writeline(r1.next(100));	// 24

random r2 = new random(1);
console.writeline(r2.next(100));	// 24

如果在创建 random 时没有提供种子,那么就将用当前系统时间来生成种子。

由于系统时钟只有有限的粒度,因此两个创建时间非常相近(一般在 10 毫秒之内)的 random 实例会生成相同的值序列。

for (int i = 0; i < 10; i++)
{
    random rd = new random();
    console.writeline(rd.next(256));
}

结果:

43
2
2
2
2
2
2
2
2
2

可以看到,这个结果中有大量的重复值。

random 的随机性安全性并不高,而 randomnumbergenerator 是一种密码强度的随机数生成器。

var rand = system.security.cryptography.randomnumbergenerator.create();
byte[] bytes = new byte[32]; 
rand.getbytes(bytes);

字节数组的长度决定了生成的随机字节数。之后用 base64 转成字符串就可以了。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网