linux内核补充随机数

linux内核补充随机数,第1张

有两种方法可以获取内核随机数。

根据博客园官网查询,一种是通过内核导出的随机数接口,另一种是通过特殊的设备文件。

Linux是一种开源电脑 *** 作系统内核。它是一个用C语言写成,符合POSIX标准的类Unix *** 作系统。

在shell中有一个环境变量RANDOM,它的范围是0--32767

1、如果我们想要产生0-25范围内的数,如何做呢?如下:

用这个环境变量对26取模,就可以得到最小是0,最大是25的数了。

2、如果想得到1--68范围内的数,可以这样

前面可以得到最小为0,最大为67的随机数,再加上1,很自然的就可以得到最大为1,最小为68的数了。

3、如果想得到6--87范围内的数。可以这样

前面可以得到最小为0,最大为81的随机数,再加上6,很自然的就可以得到最大为87,最小为6的数了。

通过上面三个例子,其它范围内的数一样可以用这种方法产生,总结出规律来

可以类推其它范围内数了

介绍:

1、/dev/random和/dev/urandom是Linux系统中提供的随机伪设备,这两个设备的任务,是提供永不为空的随机字节数据流。很多解密程序与安全应用程序(如SSH Keys,SSL Keys等)需要它们提供的随机数据流。

2、这两个设备的差异在于:/dev/random的random pool依赖于系统中断,因此在系统的中断数不足时,/dev/random设备会一直封锁,尝试读取的进程就会进入等待状态,直到系统的中断数充分够用, /dev/random设备可以保证数据的随机性。/dev/urandom不依赖系统的中断,也就不会造成进程忙等待,但是数据的随机性也不高。

3、dev/urandom 和dev/random,都是产生用不为空的随机字符流,区别是

/dev/random设备会封锁,直到系统产生的随机字符流已经充分够用,所以耗用时间较长

/dev/urandom设备不会封锁,数据的随机程度不高,但是一般情况已经够用

4、使用/dev/random比使用/dev/urandom产生大量随机数的速度要慢

通过过滤赛选可以取出随机数或随机字母如下

产生随机字母方式:

NbvFFlhs

[root@centos7 bin]#

产生随机数字方式

用途:

用来产生伪随机字节。随机数字产生器需要一个seed,先已经说过了,在没有/dev/srandom系统下的解决方法是自己做一个~/.rnd文件。如果该程序能让随机数字产生器很满意的被seeded。程序写回一些怪怪的东西回该文件。

用法:

选项说明:

-out file:结果输出到file中。

-rand file(s):指定随机数种子文件,多个文件间用分隔符分开,windows用“”,OpenVMS用“,“,其他系统用“:”。

-base64:输出结果为BASE64编码数据。

-hex:输出结果为16进制数据。

num:随机数长度。

实例:

可以看见,这12个字节的随机数显示为乱码,可以对随机字符串进行base64编码或用hex格式显示

通过过滤赛选可以取出随机数或随机字母如下

产生随机字母方式:

产生随机数字方式

四、应用

字体加颜色

\033[33m 字符 \033[0m [[31m 字符 [[0m

随机颜色

color= RANDOM%8+31]

\033[${color}m 字符 \033[0m

存放颜色案例的文件

cat /etc/DIR_COLORS

linux内核自1.3.30版本以来实现了一个随机数产生器,从理论上说它能产生真正的随机数,该随机数产生器是从设备驱动收集电路上的环境噪音放入熵池,它的实现代码在drivers/char/random.c中,自己去看吧


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/6077620.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-14
下一篇 2023-03-14

发表评论

登录后才能评论

评论列表(0条)

保存