码迷,mamicode.com
首页 > 其他好文 > 详细

产生随机密码总结

时间:2016-10-11 22:15:25      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:密码 随机

                                     产生随机密码总结

方式一:

cat /dev/urandom | sed ‘s/[^a-zA-Z0-9]//g‘ | strings -n C | head -n L

其中C表示字符串的字符数,L表示要生成多少行字符

例子:

[root@lnmp ~]# cat /dev/urandom | sed ‘s/[^a-zA-Z0-9]//g‘  |strings -n 5|head -n 1

tJxJp


方式二:

[root@lnmp ~]# cat /dev/urandom | head -1 | md5sum | head -c 8

297d5c89

只要修改最后面的”head -c 8″就可以产生你想要的随机密码了(最多可以生产32位,用做密码足够了)


方式三:

下面的方法也可以生成一个8位的随机字符串,用做密码很合适

[root@lnmp ~]# od -N 4 -t x4 /dev/random | head -1 | awk ‘{print $2}‘

59b20bfb


方式四:

[root@lnmp ~]# tr -dc "1-9"</dev/urandom|head -c 5

89284


方式五:


openssl rand 产生随机数

openssl rand 用于产生指定长度个bytes的随机字符。-base64或-hex对随机字符串进行base64编码或用hex格式显示。

openssl rand -base64 8 | md5sum | cut -c1-8    #八位字母和数字的组合,3a61800e

openssl rand -base64 8 | cksum | cut -c1-8       #八位数字,10784736



方式六:


生成一个随机密码

对于下面的任何一种方法,你可以通过简单的修改来生成特定长度的密码,或者只使用其输出结果的前N位。希望你正在使用一些类似于LastPass的密码管理器,这样你就不用自己记住这些随机生成的密码了。


1. 这种方法使用SHA算法来加密日期,并输出结果的前32个字符:

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


2. 这种方法使用内嵌的/dev/urandom,并过滤掉那些日常不怎么使用的字符。这里也只输出结果的前32个字符:

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


3. 这种方法使用openssl的随机函数。如果你的系统也许没有安装openssl,你可以尝试其它九种方法或自己安装openssl。

openssl rand -base64 32 


4. 这种方法类似于之前的urandom,但它是反向工作的。Bash的功能是非常强大的!

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


5. 这种方法使用string命令,它从一个文件中输出可打印的字符串:

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


6. 这是使用urandom的一个更简单的版本:

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


7. 这种方法使用非常有用的dd命令:

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


8. 你甚至可以生成一个只用左手便可以输入的密码:

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


9. 如果每次都使用上述某种方法,那更好的办法是将它保存为函数。如果这样做了,那么在首次运行命令之后,你便可以在任何时间只使用randpw就可以生成随机密码。或许你可以把它保存到你的~/.bashrc文件里面。

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


10. 最后这种生成随机密码的方法是最简单的。它同样也可以在安装了Cygwin的Windows下面运行。在Mac OS X下或许也可以运行。我敢肯定会有人抱怨这种方法生成的密码没有其它方法来的随机。但实际上如果你使用它生成的全部字符串作为密码,那这个密码就足够随机了。

date | md5sum 



本文出自 “IT奋斗” 博客,请务必保留此出处http://chenrj.blog.51cto.com/11045916/1860751

产生随机密码总结

标签:密码 随机

原文地址:http://chenrj.blog.51cto.com/11045916/1860751

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!