Linux操作系统的一大优点是对于同样一件事情,我们可以用多种方法来实现。当然,我们也可以用不同的方法来生成随机的密码。生成随机密码可以通过简单的修改来生成特定长度的密码,或者只使用其输出结果的前N位。当然要记得备份密码哦。那么生成这些随机密码的方法有哪些呢?
1、SHA 算法。这种方法使用SHA算法来加密日期,并输出结果的前32个字符:
date +%s | sha256sum | base64 | head -c 32 ; ech0
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、第五种方法是使用urandom的一个更简单的版本:
< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c6
6、第六种方法使用非常有用的dd命令:
dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev
7、如果每次都使用上述某种方法,那更好的办法是将它保存为函数。如果这样做了,那么在首次运行命令之后,你便可以在任何时间只使用randpw就可以生成随机密码。或许你可以把它保存到你的~/.bashrc文件里面。
randpw(){ < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo;}
以上是一些简单的生成随机密码的方法, 当然这也并不是全部的方法,对于Linux操作系来说,多寻找一些方法并不困难,对于想要生成随机密码的童鞋们,可以尝试一下哦。