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 生成指定范围随机数与随机字符串
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个字符:
1
|
date +%s | sha256sum | base64 | head -c 32 ; echo
|
2. 这种方法使用内嵌的/dev/urandom,并过滤掉那些日常不怎么使用的字符。这里也只输出结果的前32个字符:
1
|
< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-32};echo;
|
3. 这种方法使用openssl的随机函数。如果你的系统也许没有安装openssl,你可以尝试其它九种方法或自己安装openssl。
1
|
openssl rand -base64 32
|
4. 这种方法类似于之前的urandom,但它是反向工作的。Bash的功能是非常强大的!
1
|
tr -cd '[:alnum:]' < /dev/urandom | fold -w30 | head -n1
|
5. 这种方法使用string命令,它从一个文件中输出可打印的字符串:
1
|
strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 30 | tr -d '\n'; echo
|
6. 这是使用urandom的一个更简单的版本:
1
|
< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c6
|
7. 这种方法使用非常有用的dd命令:
1
|
dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev
|
8. 你甚至可以生成一个只用左手便可以输入的密码:
1
|
</dev/urandom tr -dc '12345!@#$%qwertQWERTasdfgASDFGzxcvbZXCVB' | head -c8; echo ""
|
9. 如果每次都使用上述某种方法,那更好的办法是将它保存为函数。如果这样做了,那么在首次运行命令之后,你便可以在任何时间只使用randpw就可以生成随机密码。或许你可以把它保存到你的~/.bashrc文件里面。
1
|
randpw(){ < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo;}
|
10. 最后这种生成随机密码的方法是最简单的。它同样也可以在安装了Cygwin的Windows下面运行。在Mac OS X下或许也可以运行。我敢肯定会有人抱怨这种方法生成的密码没有其它方法来的随机。但实际上如果你使用它生成的全部字符串作为密码,那这个密码就足够随机了。
1
|
date | md5sum
|
转载于:https://www.cnblogs.com/SZLLQ2000/p/4691249.html
random and password 在Linux下生成crypt加密密码的方法,shell 生成指定范围随机数与随机字符串...相关推荐
- shell 生成指定范围随机数与随机字符串 .
shell 生成指定范围随机数与随机字符串 分类: shell 2014-04-22 22:17 20902人阅读 评 ...
- shell 生成指定范围随机数与随机字符串
shell 生成指定范围随机数与随机字符串 1.使用系统的 $RANDOM 变量 fdipzone@ubuntu:~$ echo $RANDOM 17617 $RANDOM 的范围是 [0, 3276 ...
- 在Linux下生成crypt加密密码
[摘要]当我们用红帽Kickstart脚本或useradd或其他方式写东西的时候,经常会需要用到crypt命令加密生成的密码格式.那么,有没有其他方式可以生成这种格式的密码?事实上,方法有很多 1.我 ...
- ubuntu 破解mysql密码_Ubuntu下忘记MySQL root密码解决方法
Linux下忘记MySQL root密码解决方法 忘了mysql密码,从网上找到的解决方案记录在这里. 编辑mysql的配置文件/etc/mysql/my.cnf,在[mysqld]段下加入一行&qu ...
- Linux下c和cuda混合编译,并生成动态链接库.so和使用
Linux下c和cuda混合编译,并生成动态链接库.so和使用 2016-08-27 14:27 98人阅读 评论(0) 收藏 举报 分类: Linux 版权声明:本文为博主原创文章,未经博主允许不得 ...
- 【ARM-Linux开发】linux下Eclipse进行C编程时动态链接库的生成和使用
linux下Eclipse进行C编程时动态链接库的生成和使用 引用 http://linux.chinaitlab.com/soft/864157.html 欢迎进入Linux社区论坛,与200万技术 ...
- linux下mysql5.7初始密码查看及忘记密码重置
linux下mysql5.7初始密码查看及忘记密码重置 前段时间安装mysql5.7后,第一次登陆发现空密码怎么都登陆不成功,后来网上查了一下发现,从5.7开始会自动生成一个随机密码了. 查看初始密码 ...
- Linux Shell 生成随机数和随机字符串
日常生活中,会经常用到随机数,使用场景非常广泛,例如买彩票.丢骰子.抽签.年会抽奖等. Shell 下如何生成随机数呢,米扑博客特意写了本文,总结 Linux Shell 产生随机数的多种方法. 本文 ...
- 如何在linux系统下修改mysql密码_如何在linux下修改mysql数据库密码?linux修改数据库密码的方法...
本篇文章给大家带来的内容是介绍如何在linux下修改mysql数据库密码?linux修改数据库密码的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助. Linux下修改Mysql的 ...
最新文章
- QT学习第8课:QT计算器界面实现
- 前端技术学习之选择器(一)
- 独家 | 手把手教你怎样用Python生成漂亮且精辟的图像(附教程代码)
- ServiceModel 元数据实用工具 (Svcutil.exe)
- Tensorflow【实战Google深度学习框架】预训练与微调含代码(看不懂你来打我)
- tableau可视化数据分析60讲(十二)-过滤器详解
- java爬虫问题二: 使用jsoup爬取数据class选择器中空格多选择怎么解决
- 最小表达式_C# 09.找最大和最小的数字
- Codeforces 173E Camping Groups 线段树
- 【2017年第1期】基于征信数据观中国近10年产业间信贷资源的调整路径
- 【hiho】127 后缀自动机一·基本概念 【后缀自动机】
- 《Learning Scrapy》(中文版)第8章 Scrapy编程
- AWS--Lamdba
- 计算机基础高一知识点,计算机基础全部知识点_.doc
- 6G总体愿景与潜在关键技术白皮书【PPT】
- B2C电子商务开发的网店管理系统
- 什么是游戏引擎,什么是虚幻引擎(Unreal Engin 4)?
- 网页上播放视频的免费的播放器_CKPlayer
- Everyday English(四)
- 10大主流压力/负载/性能测试工具推荐
热门文章
- sqoop把mysql数据导入hive
- TypeError: type str doesn't define __round__ method
- The proof of “chi-square statistics follows chi-square distribution”
- 安装cadence ic5141时碰到字体问题
- raise errorclass(errno, errval) sqlalchemy.exc.InternalError: (pymysql.err.InternalError) (1366, u
- 项羽java_Java中高级面试题
- 页面加载成功后调用_在微信小程序里实现图片预加载组件
- 查看linux系统是32位还是64位
- 《数据结构》—— 串,KMP模式算法(转载)
- 使用Q进行同步的Promises操作