加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Shell脚本之:生成随机密码的若干种可能

发布时间:2020-12-15 16:14:09 所属栏目:安全 来源:网络整理
导读:1.生成随机密码(urandom版本) #!/bin/bash#Author:丁丁历险(Jacob)#/dev/urandom文件是Linux内置的随机设备文件#cat/dev/urandom可以看看里面的内容,ctrl+c退出查看#查看该文件内容后,发现内容有些太随机,包括很多特殊符号,我们需要的密码不希望使用这

1.生成随机密码(urandom版本)

#!/bin/bash
#Author:丁丁历险(Jacob)
#/dev/urandom文件是Linux内置的随机设备文件
#cat/dev/urandom可以看看里面的内容,ctrl+c退出查看
#查看该文件内容后,发现内容有些太随机,包括很多特殊符号,我们需要的密码不希望使用这些符号
#tr-dc'_A-Za-z0-9'</dev/urandom
#该命令可以将随机文件中其他的字符删除,仅保留大小写字母,数字,下划线,但是内容还是太多
#我们可以继续将优化好的内容通过管道传递给head命令,在大量数据中仅显示头10个字节
#注意A前面有个下划线
tr-dc'_A-Za-z0-9'</dev/urandom|head-c10

2.生成随机密码(字串截取版本)

#!/bin/bash
#Author:丁丁历险(Jacob)
#设置变量key,存储密码的所有可能性(密码库),如果还需要其他字符请自行添加其他密码字符
#使用$#统计密码库的长度
key="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
num=${#key}
#设置初始密码为空
pass=''
#循环8次,生成8为随机密码
#每次都是随机数对密码库的长度取余,确保提取的密码字符不超过密码库的长度
#每次循环提取一位随机密码,并将该随机密码追加到pass变量的最后
foriin{1..8}
do
index=$[RANDOM%num]
pass=$pass${key:$index:1}
done
echo$pass

3.生成随机密码(UUID版本,16进制密码)

#!/bin/bash
uuidgen

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

#!/bin/bash
echo$$

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读