Linux 操作系统的一大优点是对于同样一件事情,你可以使用高达数百种方法来实现它。例如,你可以通过数十种方法来生成随机密码。本文将介绍生成随机密码的十种方法。
这些方法均收集于 Command-Line Fu,并且在我们自己的 Linux PC 机上测试过。这十种方法的一些在安装了 Cygwin 的 Windows 下也是可以执行的,特别是最后一种方法。
生成一个随机密码
对于下面的任何一种方法,你可以通过简单的修改来生成特定长度的密码,或者只使用其输出结果的前 N 位。希望你正在使用一些类似于 LastPass 的密码管理器,这样你就不用自己记住这些随机生成的密码了。
1. 这种方法使用 SHA 演算法来加密日期,并输出结果的前 32 个字元:
date +%s | sha256sum | base64 | head -c 32 ; echo
2. 这种方法使用内嵌的/dev/urandom,并过滤掉那些日常不怎么使用的字元。这里也只输出结果的前 32 个字元:
< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-32};echo; 3. 这种方法使用 openssl 的随机函式。如果你的系统也许没有安装 openssl,你可以尝试其它九种方法或自己安装 openssl 。 openssl rand -base64 32 4. 这种方法类似于之前的 urandom,但它是反向工作的。 Bash 的功能是非常强大的! tr -cd ‘[:alnum:]’ < /dev/urandom | fold -w30 | head -n1 5. 这种方法使用 string 命令,它从一个档案中输出可列印的字串: strings /dev/urandom | grep -o ‘[[:alnum:]]’ | head -n 30 | tr -d ‘n’; echo 6. 这是使用 urandom 的一个更简单的版本: < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c6 7. 这种方法使用非常有用的dd命令: dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev
8. 你甚至可以生成一个只用左手便可以输入的密码: