案例四:Shell脚本生成随机密码

生成随机密码(urandom版本)
  #!/bin/bash

  #Author:丁丁历险(Jacob)

  #/dev/urandom文件是Linux内置的随机设备文件

  #cat /dev/urandom可以看看里面的内容,ctrl+c退出查看

  #查看该文件内容后,发现内容有些太随机,包括很多特殊符号,我们需要的密码不希望使用这些符号

  #tr -dc '_A-Za-z0-9'

  #该命令可以将随机文件中其他的字符删除,仅保留大小写字母,数字,下划线,但是内容还是太多

  #我们可以继续将优化好的内容通过管道传递给head命令,在大量数据中仅显示头10个字节

  #注意A前面有个下划线

  tr -dc '_A-Za-z0-9'
生成随机密码(字串截取版本)
  #!/bin/bash

  #Author:丁丁历险(Jacob)

  #设置变量key,存储密码的所有可能性(密码库),如果还需要其他字符请自行添加其他密码字符

  #使用$#统计密码库的长度

  key="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"

  num=${#key}

  #设置初始密码为空

  pass=''

  #循环8次,生成8为随机密码

  #每次都是随机数对密码库的长度取余,确保提取的密码字符不超过密码库的长度

  #每次循环提取一位随机密码,并将该随机密码追加到pass变量的最后

  for i in {1..8}

  do

               index=$[RANDOM%num]

              pass=$pass${key:$index:1}

  done

  echo $pass
生成随机密码(UUID版本,16进制密码)
  #!/bin/bash

  uuidgen

  4.生成随机密码(进程ID版本,数字密码)

  #!/bin/bash

  echo $$

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/linux/120407.html

(0)
上一篇 2021年8月28日 12:06
下一篇 2021年8月28日 12:06

相关推荐

发表回复

登录后才能评论