Linux系统产生随机数的方法
1. 通过系统环境变量($RANDOM)实现
echo $RANDOM
注意:
RANDOM的随机数范围为0 ~ 32767,因此,加密性不是很好。
解决办法:
可以通过在随机数后增加加密字符串(就是和密码生成有关的字符串)的方式解决,最后再一起执行md5sum操作并截取结果的后n位,这样一来,就无法根据随机范围0~32767猜出具体结果了。
echo "westos-dd$RANDOM"
echo "westos-dd$RANDOM" | md5sum
echo "westos-dd$RANDOM" | md5sum | cut -c 8-15
2. 通过openssl产生随机数
令数字与大小写字符相结合,并带上特殊字符,可以达到很长的位数,这样的随机数很安全。
openssl rand -base64 8
openssl rand -base64 80
openssl rand -base64 100
注意:后面跟的数字单位不是长度而是比特
3. 通过date获得随机数
date
date +%s
date +%s%N
4. 实战训练
例1:
代码:
#!/bin/bash
path=/westos
[ -d "$path" ] || mkdir -p $path
for n in `seq 10`
do
random=$(openssl rand -base64 40|sed 's/[^a-z]//g'|cut -c 3-11)
#random=$(echo $RANDOM |md5sum |sed 's/[^a-z]//g') #和上一行效果相同
touch $path/${random}_westos.html
done
执行结果:
例2:
代码:
#!/bin/bash
. /etc/init.d/functions
user="westos"
passfile="/tmp/user.log"
for n in `seq -w 10`
do
pass="`echo $RANDOM |md5sum |cut -c 3-11`"
useradd $user$n &>/dev/null && {
echo "$pass"|passwd --stdin $user$n &>/dev/null
echo -e "user: $user$n\tpasswd:$pass">>$passfile
}
if [ $? -eq 0 ]
then
action "$user$n is ok" /bin/true
else
action "$user$n"is fail /bin/false
fi
done
echo --------------------------
cat $passfile && >$passfile
执行结果: