shell生成一個隨機密碼
Linux操作系統的一大優點是對於同樣一件事情,你可以使用高達數百種方法來實現它。例如,你可以通過數十種方法來生成隨機密碼。本文將介紹生成隨機密碼的十種方法。
這些方法均收集於Command-Line Fu,並且在我們自己的Linux PC機上測試過。這十種方法的一些在安裝了Cygwin的Windows下也是可以運行的,特別是最後一種方法。
生成一個隨機密碼
對於下面的任何一種方法,你可以通過簡單的修改來生成特定長度的密碼,或者只使用其輸出結果的前N位。希望你正在使用一些類似於LastPass的密碼管理器,這樣你就不用自己記住這些隨機生成的密碼了。
1. 這種方法使用SHA算法來加密日期,並輸出結果的前32個字符:
1 | date +%s | sha256sum | base64 | head -c 32 ; echo |
2. 這種方法使用內嵌的/dev/urandom,並過濾掉那些日常不怎麽使用的字符。這裏也只輸出結果的前32個字符:
Shell1 | < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-32};echo; |
3. 這種方法使用openssl的隨機函數。如果你的系統也許沒有安裝openssl,你可以嘗試其它九種方法或自己安裝openssl。
1 | openssl rand -base64 32 |
4. 這種方法類似於之前的urandom,但它是反向工作的。Bash的功能是非常強大的!
1 | tr -cd ‘[:alnum:]‘ < /dev/urandom | fold -w30 | head -n1 |
5. 這種方法使用string命令,它從一個文件中輸出可打印的字符串:
Shell1 |
strings /dev/urandom | grep -o ‘[[:alnum:]]‘ | head -n 30 | tr -d ‘\n‘; echo |
6. 這是使用urandom的一個更簡單的版本:
Shell1 | < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c6 |
7. 這種方法使用非常有用的dd命令:
Shell1 | dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev |
8. 你甚至可以生成一個只用左手便可以輸入的密碼:
Shell1 | </dev/urandom tr -dc ‘12345!@#$%qwertQWERTasdfgASDFGzxcvbZXCVB‘ | head -c8; echo "" |
9. 如果每次都使用上述某種方法,那更好的辦法是將它保存為函數。如果這樣做了,那麽在首次運行命令之後,你便可以在任何時間只使用randpw就可以生成隨機密碼。或許你可以把它保存到你的~/.bashrc文件裏面。
Shell1 | randpw(){ < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo;} |
10. 最後這種生成隨機密碼的方法是最簡單的。它同樣也可以在安裝了Cygwin的Windows下面運行。在Mac OS X下或許也可以運行。我敢肯定會有人抱怨這種方法生成的密碼沒有其它方法來的隨機。但實際上如果你使用它生成的全部字符串作為密碼,那這個密碼就足夠隨機了。
Shell1 | date | md5sum |
是的,這種方法也極其好記。
shell生成一個隨機密碼