系统相关
首页 > 系统相关> > 【14】shell:生成随机数

【14】shell:生成随机数

作者:互联网

【14】shell:生成随机数

文章目录

一、通过系统环境变量($RANDOM)实现


RANDOM 的随机数范围为 0 ~ 32767,因此,加密性不是很好,可以通过在随机数后增加加密字符串(就是和密码生成有关的字符串)的方式解决,最后再通过 cut 截取结果的部分数据,这样一来,就无法根据随机范围 0 ~ 32767 猜出具体结果了。示例如下:

$ echo $RANDOM
3034

$ echo $RANDOM | md5sum | cut -c 5-15
b3b5cfa20b9

二、通过openssl产生随机数


$ openssl rand -base64 8
yB0maNWRoQw=

令数字与大小写字符相结合,并带上特殊字符,可以达到很长的位数,这样的随机数很安全。

三、通过时间(date)获取随机数


$ date +%s%N
1523402619479946400

四、通过/dev/urandom配合chksum生成随机数


$ head /dev/urandom|cksum
2866845253 2890

/dev/random 设备存储着系统当前运行环境的实时数据。它可以看作系统在某个时候的唯一值,因此可以用作随机元数据。我们可以通过文件读取的方式,读到里面的数据。/dev/urandom 这个设备的数据与 random 里的一样。只是,它是非阻塞的随机数发生器,读取操作不会产生阻塞。

五、通过UUID生成随机数


$ cat /proc/sys/kernel/random/uuid
c984eb24-9524-4b07-af80-8b18b5a1b530

UUID码全称是通用唯一识别码(Universally Unique Identifier,UUID)它是一个软件建构的标准,亦为自由软件基金会的组织在分布式计算环境领域的一部分;
UUID的目的是让分布式系统中的所有元素都能有唯一的辨别信息,而不需要通过中央控制端来做辨别信息的指定,如此一来,每个人都可以创建不与其他人发生冲突的UUID,在这种情况下,就不需要考虑数据库创建时的名称重复问题了,它会让网络中任何一台计算机所生成的UUID码都是互联网整个服务器网路中唯一的编码。它的原信息会加入硬件、时间、机器当期那运行信息等。

六、通过 mkpasswd 生成随机数


mkpasswd -l 9 -d 2 -c 3 -s 1
VxqE}t56o

相关参数说明如下:

七、随机数长短不一,可以使用 md5sum 配合 cut 统一格式


$ mkpasswd -l 9 -d 2 -c 3 -C 3 -s 1|md5sum|cut -c 2-10
8bbff4c99

$ cat /proc/sys/kernel/random/uuid|md5sum|cut -c 2-10
140edad51

$ head /dev/urandom|cksum|md5sum|cut -c 2-10
6c637bba0

$ date +%s%N|md5sum|cut -c 2-10
9da12f186

$ openssl rand -base64 80|md5sum|cut -c 2-10
d165ada49

$ echo "test$RANDOM"|md5sum|cut -c 2-10
145c845ee

标签:10,cut,14,md5sum,RANDOM,shell,随机数,UUID
来源: https://blog.csdn.net/focus_lyh/article/details/112381204