建立隨機數的方法:
複製代碼 代碼如下:
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;i<10;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"