利用Linux系统生成随机密码的8种方法
来源于:https://www.cnblogs.com/dadonggg/p/8477655.html
Linux操作系统的一大优点是对于同样一件事情,你可以使用高达数百种方法来实现它。例如,你可以通过数十种方法来生成随机密码。本文将介绍生成随机密码的十种方法。
使用SHA算法来加密日期,并输出结果的前10个字符:
date +%s |sha256sum |base64 |head -c 10 ;echo YTc4Mjk0Yj
- 使用内嵌的/dev/urandom,并过滤掉那些日常不怎么使用的字符。这里也只输出结果的前32个字符:
tr参数
- -c或——complerment:取代所有不属于第一字符集的字符;
- -d或——delete:删除所有属于第一字符集的字符;
1.生成10个小写字母
</dev/urandom tr -dc a-z|head -c ${1:-10};echo iprnfrqlhr
2.生成10个大写字母
</dev/urandom tr -dc A-Z|head -c ${1:-10};echo PSKSFZYQPH
3.生成10个数字
</dev/urandom tr -dc 0-9|head -c ${1:-10};echo 7341384592
4.生成10个数字和大写字母的组合字符串
</dev/urandom tr -dc 0-9-A-Z|head -c ${1:-10};echo M6HP4LHTNJ
5.生成10个随机字符(包含数字,大写字母,小写字母)
</dev/urandom tr -dc 0-9-A-Z-a-z|head -c ${1:-10};echo 79JUYcjrjx
6.生成10个随机字符(包含数字,大写字母,小写字母)
</dev/urandom tr -dc 0-9-A-Z-a-z-|head -c ${1:-10};echo JdOi4TMmZD
7.生成10个随机字符(包含数字,大写字母,小写字母,特殊字符)
s5-yTgMa8G
使用openssl的随机函数
openssl rand -base64 10 6kf9CHiiRgiSVQ==
openssl rand -base64 10|tr A-Z a-z 1ivhbhsrvjsfsa==
openssl rand -base64 32|tr A-Z a-z|cut -c 1-10 hbxd/42tag
这种方法类似于之前的urandom,但它是反向工作的。
tr -cd '[:alnum:]' PezxAXSxVNKL3GQcjovgmoiIaDVByxXT tr -cd '[:alnum:]' b1r4qLm09S
使用string命令,它从一个文件中输出可打印的字符串
strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 32 | tr -d '\n'; echo zFSi9lMfBe6igWotELx0O85sx1hL2ux7
这是使用urandom的一个更简单的版本
cBdmH-Y7fPzROb4pjCMV7CWK75OHcXgV oyglc4qzbd54alegng40k0kvrb8m6q9k qzghgesb2w
使用非常有用的dd命令
dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev T5cfmBaTX1xcUo+aa4wK+XKF/ydh1VqovEyl8oCxmsw dd if=/dev/urandom bs=1 count=10 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev KQqr7OPAoaHsIg=
版权申明
本文系作者 @天边的云 原创发布在Loshub站点。未经许可,禁止转载。
暂无评论数据