創建隨機數的方法:
復制代碼 代碼如下:
1~~~~
/dev/urandom
在Linux中有一個設備/dev/urandom是用來產生隨機數序列的。利用該設備我們可以根據在需要生成隨機字符串。
比如我們要產生一個8位的字母和數字混合的隨機密碼,可以這樣:
復制代碼 代碼如下:
[linux@test /tmp]$ cat /dev/urandom | head -1 | md5sum | head -c 8
6baf9282
2~~~~
其實,linux已經提供有個系統環境變量了。
復制代碼 代碼如下:
[chengmo@centos5 shell]$ echo $RANDOM
66918
[chengmo@centos5 shell]$ echo $RANDOM
10092
可能有疑問了,如果超過5位的隨機數怎么得到呢?
十位數的話,用%取10余數
復制代碼 代碼如下:
echo $((RANDOM%10))
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
vi passwd.sh
#創建一個 10 位的隨機的密碼。。。
#!/bin/bash
a=(a b c d e A B C D E F @ $ % ^ 0 1 2 3 4 5 6 7 8 9)
for ((i=0;i10;i++));do
echo -n ${a[$RANDOM % ${#a[@]}]}
done
echo
執行腳本:
復制代碼 代碼如下:
[root@2 shell]# sh passwd.sh
BF8366c@13
vi useradd.sh
#創建5個賬號,引用了隨機的密碼。
#!/bin/bash
i=1
while [ $i -le 5 ]
do
useradd red$i
a=`sh ./passwd.sh`
echo " red$i:$a " >> sumuserpasswd
echo "~~~~~~~~~~~" >> sumuserpasswd
echo red$i:$a|chpasswd
# echo $a | passwd –-stdin red"$i"
let i++
done
執行:sh useradd.sh
復制代碼 代碼如下:
[root@2 shell]# cat /etc/passwd|grep red
red1:x:515:515::/home/red1:/bin/bash
red2:x:516:516::/home/red2:/bin/bash
red3:x:517:517::/home/red3:/bin/bash
red4:x:518:518::/home/red4:/bin/bash
red5:x:519:519::/home/red5:/bin/bash
#查看結果
[root@2 shell]# cat sumuserpasswd
red1:$Ca7%298d2
~~~~~~~~~~~~~
red2:eEaBBB7Fb4
~~~~~~~~~~~~~
red3:%3E385cecE
~~~~~~~~~~~~~
red4:3@F%@B0584
~~~~~~~~~~~~~
red5:AdEe^6BF$F
#測試一下
[root@2 shell]# su red1
[red1@2 shell]$ su red2
口令:
[red2@2 shell]$
也可以用html的方式來顯示我們的結果:
html表格代碼
復制代碼 代碼如下:
body>
tableborder='1'>
tr>
td>user/td>
td>passwd/td>
/tr>
tr>
td>test1/td>
td>123123/td>
/tr>
tr>
td>test2/td>
td>aaabbb/td>
/tr>
/table>
/body>
可以把賬號和密碼以html語法的方式導向到網頁里面
復制代碼 代碼如下:
TEMP=index.html
echo "html>body>h3>賬號和密碼/h3>" > $TEMP
echo "tableborder=\"1\">" >> $TEMP
echo "tr>td>username/td>td>password/td>/tr>>> $TEMP
echo "tr>td>$i/td>td>$a/td>/tr>" >> $TEMP
echo "/table>/body>/html>" >>$TEMP
echo "open index.html"
您可能感興趣的文章:- 詳解Linux Shell 實現一個獲取任意位數的隨機密碼的腳本
- PowerShell生成隨機密碼的方法
- Shell腳本生成隨機密碼的若干種可能