日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

random and password 在Linux下生成crypt加密密码的方法,shell 生成指定范围随机数与随机字符串...

發布時間:2023/12/19 linux 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 random and password 在Linux下生成crypt加密密码的方法,shell 生成指定范围随机数与随机字符串... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

openssl rand -hex n (n is number of characters)

LANG=c < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo; (生成隨機密碼16)

?

shell 生成指定范圍隨機數與隨機字符串

?

熱度5?評論?245

www.BkJia.Com??網友分享于:??2014-04-23 12:04:43?????瀏覽數10854次

?

shell 生成指定范圍隨機數與隨機字符串

?

1.使用系統的 $RANDOM 變量

?

fdipzone@ubuntu:~$ echo $RANDOM 17617 $RANDOM 的范圍是 [0, 32767]

?

如需要生成超過32767的隨機數,可以用以下方法實現。

例:生成400000~500000的隨機數

?

#!/bin/bashfunction rand(){min=$1max=$(($2-$min+1))num=$(($RANDOM+1000000000)) #增加一個10位的數再求余echo $(($num%$max+$min)) }rnd=$(rand 400000 500000) echo $rndexit 0

2.使用date +%s%N

例:生成1~50的隨機數

?

#!/bin/bashfunction rand(){min=$1max=$(($2-$min+1))num=$(date +%s%N)echo $(($num%$max+$min)) }rnd=$(rand 1 50) echo $rndexit 0
3.使用/dev/random 和 /dev/urandom

?

/dev/random?存儲著系統當前運行環境的實時數據,是阻塞的隨機數發生器,讀取有時需要等待。

/dev/urandom?非阻塞隨機數發生器,讀取操作不會產生阻塞。

例:使用/dev/urandom生成100~500的隨機數,使用urandom避免阻塞。

?

#!/bin/bashfunction rand(){min=$1max=$(($2-$min+1))num=$(cat /dev/urandom | head -n 10 | cksum | awk -F ' ' '{print $1}')echo $(($num%$max+$min)) }rnd=$(rand 100 500) echo $rndexit 0
4.使用linux uuid

?

uuid?全稱是通用唯一識別碼,格式包含32個16進制數字,以'-'連接號分為5段。形式為8-4-4-4-12 的32個字符。

?

fdipzone@ubuntu:~/shell$ cat /proc/sys/kernel/random/uuid fd496199-372a-403e-8ec9-bf4c52cbd9cd 例:使用linux uuid 生成100~500隨機數

?

?

#!/bin/bashfunction rand(){min=$1max=$(($2-$min+1))num=$(cat /proc/sys/kernel/random/uuid | cksum | awk -F ' ' '{print $1}')echo $(($num%$max+$min)) }rnd=$(rand 100 500) echo $rndexit 0
5.生成隨機字符串

?

例:生成10位隨機字符串

?

#使用date 生成隨機字符串 date +%s%N | md5sum | head -c 10#使用 /dev/urandom 生成隨機字符串 cat /dev/urandom | head -n 10 | md5sum | head -c 10

這個命令就是用來生成crypt格式的密碼的:?

mkpasswd?

  輸入命令后,程序會要求輸入一個密碼,然后生成crypt格式的字符串。?

  如果用Apache Web服務器,那么也可以用htpasswd:?

htpasswd -nd user?

  用戶名(user)叫什么都無所謂,我們關注的是密碼。這個命令會輸出一個user:password格式的字符串,直接把password字段復制下來就ok了。?

  有OpenSSL的話,可以使用openssl命令:?

openssl passwd -crypt myPassword?

  把上面命令中的myPassword用你想用的密碼字符串代替。?

  其他還有一些需要把命令在命令行中直接輸入的方式,不過這種做法有個問題,就是在ps命令中可以看到密碼,同時密碼也會被記錄入shell歷史。?

  不過這個問題是有解決辦法的:用腳本,或者語言解釋器。?

  比如使用Perl:?

  perl -e "print crypt('password','sa');"?

  Perl需要一個加密鹽,如這里使用了sa(salt指加密中用到的隨機字符串,用不同的salt可以生成不同的加密結果)。?

  Ruby也一樣需要加密鹽:?

  ruby -e 'print "password".crypt("JU"); print("\n");'?

  PHP也可以:?

  php -r "print(crypt('password','JU') . \"\n\");"?

  需要注意的是,如果不使用加密鹽(如上面命令中的JU),那么輸出的字符串將不是crypt加密格式,而是MD5加密格式的。所以,加密鹽其實是必須的參數。?

  Python需要導入crypt庫并使用加密鹽:?

  python -c 'import crypt; print crypt.crypt("password","Fx")'?

  這里的加密鹽是Fx。?

  數據庫也可以生成crypt密碼。比如用MySQL:?

  echo "select encrypt('password');" | mysql?

  另外,Tcl,Ubuntu下的trf,還有Lua的lua-crypt插件也可以實現相同的目的。

?

生成一個隨機密碼

對于下面的任何一種方法,你可以通過簡單的修改來生成特定長度的密碼,或者只使用其輸出結果的前N位。希望你正在使用一些類似于LastPass的密碼管理器,這樣你就不用自己記住這些隨機生成的密碼了。

1. 這種方法使用SHA算法來加密日期,并輸出結果的前32個字符:

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

2. 這種方法使用內嵌的/dev/urandom,并過濾掉那些日常不怎么使用的字符。這里也只輸出結果的前32個字符:

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

3. 這種方法使用openssl的隨機函數。如果你的系統也許沒有安裝openssl,你可以嘗試其它九種方法或自己安裝openssl。

Shell
1 openssl rand -base64 32

4. 這種方法類似于之前的urandom,但它是反向工作的。Bash的功能是非常強大的!

1 tr -cd '[:alnum:]' < /dev/urandom | fold -w30 | head -n1

5. 這種方法使用string命令,它從一個文件中輸出可打印的字符串:

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

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

Shell
1 < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c6

7. 這種方法使用非常有用的dd命令:

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

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

Shell
1 </dev/urandom tr -dc '12345!@#$%qwertQWERTasdfgASDFGzxcvbZXCVB' | head -c8; echo ""

9. 如果每次都使用上述某種方法,那更好的辦法是將它保存為函數。如果這樣做了,那么在首次運行命令之后,你便可以在任何時間只使用randpw就可以生成隨機密碼。或許你可以把它保存到你的~/.bashrc文件里面。

Shell
1 randpw(){ < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo;}

10. 最后這種生成隨機密碼的方法是最簡單的。它同樣也可以在安裝了Cygwin的Windows下面運行。在Mac OS X下或許也可以運行。我敢肯定會有人抱怨這種方法生成的密碼沒有其它方法來的隨機。但實際上如果你使用它生成的全部字符串作為密碼,那這個密碼就足夠隨機了。

Shell
1 date | md5sum

轉載于:https://www.cnblogs.com/SZLLQ2000/p/4691249.html

總結

以上是生活随笔為你收集整理的random and password 在Linux下生成crypt加密密码的方法,shell 生成指定范围随机数与随机字符串...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。