Shell脚本生成随机密码的若干种可能
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 -c 10
2.生成随机密码(字串截取版本)
#!/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
3.生成随机密码(UUID版本,16进制密码)
#!/bin/bash uuidgen
4.生成随机密码(进程ID版本,数字密码)
#!/bin/bash echo $$
总结
相关推荐
彼岸随笔 2020-10-20
yutou0 2020-10-17
jarrygao 2020-11-02
shipinsky 2020-09-23
touchfuture 2020-09-16
hongsheyoumo 2020-09-04
tianhuak 2020-11-24
huha 2020-10-16
lianshaohua 2020-09-23
laisean 2020-11-11
zhangjie 2020-11-11
大牛牛 2020-10-30
firefaith 2020-10-30
liguojia 2020-10-20
wangzhaotongalex 2020-10-20
以梦为马不负韶华 2020-10-20
CARBON 2020-10-20
lianshaohua 2020-10-20
JohnYork 2020-10-16