• linux系统产生随机数的6种方法


    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 ~]#

     

  • 相关阅读:
    前端攻城狮学习笔记九:让你彻底弄清offset
    JavaScript中Element与Node的区别,children与childNodes的区别
    JavaScript代码优化实战之一:缓存变量,关键字过滤
    【转】纯CSS画的基本图形(矩形、圆形、三角形、多边形、爱心、八卦等),NB么
    包装对象——JavaScript中原始类型拥有属性的原因
    关于两个容积不同的瓶子中装水可以得到哪些精确值的问题的算法
    JavaScript中判断鼠标按键(event.button)
    累了休息一会儿吧——分享一个JavaScript版扫雷游戏
    用CSS让未知高度内容垂直方向居中
    空间换时间,把递归的时间复杂度降低到O(2n)
  • 原文地址:https://www.cnblogs.com/Mr-Ding/p/9427968.html
Copyright © 2020-2023  润新知