1. 程式人生 > >Linux下生成隨機密碼(轉)

Linux下生成隨機密碼(轉)

1、使用SHA演算法來加密日期,並輸出結果的前32個字元:

date +%s |sha256sum |base64 |head -c 32 ;echo

生成結果如下:
ZTNiMGM0NDI5OGZjMWMxNDlhZmJmNGM4

2、使用內嵌的/dev/urandom,並過濾掉那些日常不怎麼使用的字元。這裡也只輸出結果的前32個字元:

< /dev/urandom tr -dc _A-Z-a-z-0-9 |head -c${1:-32};echo

生成結果如下:
pDj0Xwz7exD_Qb5B27BwWsM1hrF3a7cJ

3、使用openssl的隨機函式(推薦使用這個,好記)

openssl rand -base64 32

生成結果如下:
rYJWqJlTLAYeX3j7nCbir20h1k/0CnqLNEuNyTScfKo=

4、這種方法類似於之前的urandom,但它是反向工作的

tr -cd '[:alnum:]' < /dev/urandom | fold -w32 | head -n1;echo

生成結果如下:
tpgudzF7sqtU4yyW2LVhmUQOZIQi87

5、使用string命令,它從一個檔案中輸出可列印的字串

strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 32 | tr -d '\n'; echo

生成結果如下:
W4v1iQtkmQ8sIDd9jxDQNpg8HPMOZ8

6、這是使用urandom的一個更簡單的版本

< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo

生成結果如下:
rMDlGSPN_bm-IZVFWz9BEi0rF-jIy6gs

7、使用非常有用的dd命令

dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev

生成結果如下:
9+0RUd4U3HmSdMlgD7j0sf/r09MZFDVBS28W+pO2WcA

8、你甚至可以生成一個只用左手便可以輸入的密碼

</dev/urandom tr -dc '
[email protected]
#$%qwertQWERTasdfgASDFGzxcvbZXCVB' | head -c32; echo 生成結果如下: VTG3#TR4sAgXg3Z%##[email protected]$wdqF

9、如果每次都使用上述某種方法,那更好的辦法是將它儲存為函式。如果這樣做了,那麼在首次執行命令之後,你便可以在任何時間只使用randpw就可以生成隨機密碼。或許你可以把它儲存到你的~/.bashrc檔案裡面

原文連結