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
#< /dev/urandom tr -dc _a-z-a-z-0-19 | 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 po2wca8. 你甚至可以產生一個只用左手便可以輸入的密碼
##產生結果如下:
vtg333 #tr4sagxg3z%##wzg4zq@gz$wdqf
#9. 如果每次都使用上述某種方法,那麼更好的方法就是將它儲存為函數。如果這樣做了,那麼在首次運行指令之後,你便可以在任何時間只使用randpw就可以產生隨機密碼。或許你可以把它存到你的~/.bashrc檔案裡面
randpw(){ < /dev/urandom tr -dc _a-z-a-z-0-9 | head -c${ 1:-16};echo;}
產生結果如下:
vgbx8cno950riykzrppya4bvbavzby_x
#10. 最後這種產生隨機密碼的方法是最簡單的。它同樣也可以在安裝了cygwin的windows下面運作。在mac os x下也可以運作。我敢肯定會有人抱怨這種方法產生的密碼沒有其它方法來的隨機。但實際上如果你使用它產生的全部字串作為密碼,那麼這個密碼就足夠隨機了
date | md5sum
產生結果如下:
e0d057b46a9a78346cbd94b25e574e79 -date | base64
產生結果如下:
mjaxnow5tcawn acicazmeaxpsdmmj/#mjaxnow5tcawn acicazmeaxpsdm
產生結果如下:7c4243742aa515d45c12deca31428a95 -
#甚至你想產生一個核彈發射密碼都可以,下面是一個產生長密碼的例子; ifconfig | base64
產生結果如下:
zw0xicagicagiexpbmsgzw5jyxa6rxrozxjuzxqgiehxywrkcia3odoyqjpdqjoyqjpcmdo55xjuzxqgiehxywrkcia3odoyqjpdqjoyqjpcmdo55g; 5mi4xnjgumy4yntugie1h
c2s6mju1lji1ns4yntuumaogicagicagicagaw5lddygywrkcjogzmu4mdo6n2eyyjpjymzmomzl
mmi6yja5nc82ncbty29wzftbwbty29wz qgie1uvtoxntawicbnzxryawm6mqogicagicagicagulggcgfja2v0czoymdy3nty0igvy
cm9yczowigryb3bwzwq6mcbvdmvycnvuczowigzyyw1lojakicagicagicagifryihbhy2tldhm6
odg2ndugzxjyb3jzojagzhjvchblzdow wxlbjoxmdawiaogicagicagicagulggynl0zxm6mjazndkzntex
icgxotqumcbnauipicbuwcbiexrlczozmjuynzuxniaomzeumcbnauipcgpsbyagicagicagtglu
ay 4xicbn
yxnroji1ns4wljaumaogicagicagicagaw5lddygywrkcjogojoxlzeyocbty29wztpib3n0ciag
icagicagicbvucbmt09qqkfdsybsvu5osu5hicbnvica6mvucbmt09qqkf kzmsblcnjvcnm6mcbkcm9wcgvkojagb3zlcnj1bnm6mcbmcmftztow
ciagicagicagicbuwcbwywnrzxrzoju2otkzmsblcnjvcnm6mcbkcm9wcgvkojagb3zK1bp 0ehf1zxvlbgvuojagciagicagicag
icbswcbiexrlczozmzezmdcxosaomzeunsbnauipicbuwcbiexrlczozmzezmdcxosaomzeunsbn
auipcgo=
以上是Linux產生隨機密碼的方法有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!