linux系统产⽣随机数的6种⽅法
⽅法⼀:通过系统环境变量($RANDOM)实现:
[root@test ~]# echo $RANDOM
11595
[root@test ~]# echo $RANDOM
21625
RANDOM的随机数范围为0~32767,因此,加密性不是很好,可以通过在随机数后增加加密字符串(就是和密码⽣成有关的字符串)的⽅式解决,最后再⼀起执⾏md5sum操作并截取结果的后n位,这样⼀来,就⽆法根据随机范围0~32767猜出具体结果了。
⽰例:
[root@test ~]# echo "$RANDOM"|md5sum|cut -c 5-15
4eaf70019cc
⽅法⼆:通过openssl产⽣随机数,⽰例:
[root@test ~]# openssl rand -base64 8
yB0maNWRoQw=
令数字与⼤⼩写字符相结合,并带上特殊字符,可以达到很长的位数,这样的随机数很安全。
⽅法三:通过时间(date)获取随机数,⽰例:
[root@test ~]# date +%s%N
1523402619479946400
[root@test ~]# date +%s%N
1523402622015235600
⽅法四:通过/dev/urandom配合chksum⽣成随机数:
[root@test ~]# head /dev/urandom|cksum
2866845253 2890
[root@test ~]# head /dev/urandom|cksum
2131526544 2440
/dev/random设备存储着系统当前运⾏环境的实时数据。它可以看作系统在某个时候的唯⼀值,因此可以⽤作随机元数据。我们可以通过⽂件读取的⽅式,读到⾥⾯的数据。/dev/urandom这个设备的数据与random⾥的⼀样。只是,它是⾮阻塞的随机数发⽣器,读取操作不会产⽣阻塞。
⽅法五:通过UUID⽣成随机数,⽰例:
[root@test ~]# cat /proc/sys/kernel/random/uuid
c984eb24-9524-4b07-af80-8b18b5a1b530
[root@test ~]# cat /proc/sys/kernel/random/uuid
28274c2f-c03b-4c6a-9bd2-d20b594972a4
UUID码全称是通⽤唯⼀识别码(Universally Unique Identifier,UUID)它是⼀个软件建构的标准,亦为
⾃由软件基⾦会的组织在分布式计算环境领域的⼀部分;
UUID的⽬的是让分布式系统中的所有元素都能有唯⼀的辨别信息,⽽不需要通过中央控制端来做辨别信息的指定,如此⼀来,每个⼈都可以创建不与其他⼈发⽣冲突的UUID,在这种情况下,就不需要考虑数据库创建时的名称重复问题了,它会让⽹络中任何⼀台计算机所⽣成的UUID码都是互联⽹整个服务器⽹路中唯⼀的编码。它的原信息会加⼊硬件、时间、机器当期那运⾏信息等。
⽅法六:使⽤expect附带的mkpasswd⽣成随机数;mkpasswd命令依赖于数据包expect,因此必须通过"yum install expect -y"命令先安装该数据包。⽰例:
[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -s 1
VxqE}t56o
[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -s 1
W99syAyf;
[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -s 1
snll4LX6<
相关参数说明如下:
-l #      (length of password, default = 9)    #指定密码长度;
-d #      (min # of digits, default = 2)    #指定密码中数字的数量;
-c #      (min # of lowercase chars, default = 2)        #指定密码中⼩写字母的数量;
-C #      (min # of uppercase chars, default = 2)    #指定密码中⼤写字母的数量;
-s #      (min # of special chars, default = 1)    #指定密码中特殊字符的数量;
-p prog  (program to set password, default = /bin/passwd)    #程序设置密码,默认是passwd;
上⾯的随机数长短不⼀,可以使⽤md5sum统⼀格式:
[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -C 3 -s 1|md5sum|cut -c 2-10
8bbff4c99
[root@test ~]# cat /proc/sys/kernel/random/uuid|md5sum|cut -c 2-10
140edad51
[root@test ~]# head /dev/urandom|cksum|md5sum|cut -c 2-10字符串截取后六位
6c637bba0
[root@test ~]# date +%s%N|md5sum|cut -c 2-10
9da12f186
[root@test ~]# openssl rand -base64 80|md5sum|cut -c 2-10
d165ada49
[root@test ~]# echo "test$RANDOM"|md5sum|cut -c 2-10
145c845ee
[root@test ~]#

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。