美文网首页
随机数产生的6种办法

随机数产生的6种办法

作者: 大叔David | 来源:发表于2019-06-29 11:18 被阅读0次

方法一:
通过系统环境变量($RANDOM)实现:

[root@web01 david]# echo $RANDOM
9236
[root@web01 david]# echo $(($RANDOM+11111111))
11128230
[root@web01 david]# echo $(($RANDOM+22222222))
22238612
[root@web01 david]# echo $(($RANDOM+45645689))
45648816

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

[root@test ~]# echo "$RANDOM"|md5sum|cut -c 5-15
4eaf70019cc

方法二:
通过openssl产生8位随机数,示例:

[root@web01 david]# openssl rand -base64 8
giKvexw0VXo=

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

方法三:
通过时间(date)获取随机数,示例:

[root@web01 david]# date +%s%N
1561778055521886139
[root@web01 david]# date +%s%N
1561778057417827462

方法四:
通过/dev/urandom配合chksum生成随机数:

[root@web01 david]# head /dev/urandom|cksum
1400149309 2720
[root@web01 david]# head /dev/urandom|cksum
1664147293 2773

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

方法五:
通过UUID生成随机数,示例:

[root@web01 david]# cat /proc/sys/kernel/random/uuid
4cefb900-29ce-4515-88c4-7773d2aaa93d
[root@web01 david]# cat /proc/sys/kernel/random/uuid
c8f47170-b5a6-4c0a-a0ce-5900fa8692fc

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

方法六:
使用expect附带的mkpasswd生成随机数;mkpasswd命令依赖于数据包expect,因此必须通过"yum install expect -y"命令先安装该数据包。示例:

[root@web01 david]# mkpasswd -l 9 -d 2 -c 3 -s 1
1L~1Kusjm
[root@web01 david]# mkpasswd -l 9 -d 2 -c 3 -s 1
2kO1~riRb
[root@web01 david]# mkpasswd -l 9 -d 2 -c 3 -s 1
?ut30SXzg

相关参数说明如下:

-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

相关文章

  • 随机数产生的6种办法

    方法一:通过系统环境变量($RANDOM)实现: RANDOM的随机数范围为0-32767,因此,加密性不是很好,...

  • c++随机数

    c++产生若干随机数 产生某一区间的随机数

  • 系统随机数产生方法

    1、通过系统环境变量($RANDOM)产生随机数 2、通过openssl产生随机数 3、通过时间获得随机数(dat...

  • srand48(time(0))随机产生一种颜色

    计算机产生的随机数并不是真正随机的,所以叫 伪随机数。当“种子”固定时,它产生的随机数序列是不变的,例如产生10个...

  • c#中产生随机数方法

    一:产生指定范围内的几个随机数 二:产生0~100的一个随机数

  • java 获取随机数

    java产生随机数的3种方式 一.使用Math.random()方法 Math.random() 产生的随机数是0...

  • 命令行参数-Djava.security.egd=file:/d

    背景 在java开发中广泛使用SecureRandom,产生可靠随机数。但在大量产生随机数的场景下,性能会较低。 ...

  • 随机数

    rand:当程序运行起来,系统自动产生一个种子(产生随机数的小系统,需要一个参考点),使用rand产生随机数之后,...

  • 喵神swifter学习笔记

    1、随机数 不需要随机数种子 arc4random()%N + begin:产生begin~begin+N的随机数...

  • JAVA Random类 及 产生验证码

    //随机数类 Random /* * 虽然 Math类 也带有 产生随机数的方法 Math.random();...

网友评论

      本文标题:随机数产生的6种办法

      本文链接:https://www.haomeiwen.com/subject/tinucctx.html