欢迎各界计算机爱好者加入,弘扬极客精神!

利用Linux系统生成随机密码的10种方法

0 喜欢 0 不喜欢
最新提问 9月 20, 2016 分类:菜鸟问 | 用户: 45° (1,542 分)  

11 个回答

0 喜欢 0 不喜欢
 
已采纳

使用SHA算法来加密日期,并输出结果的前32个字符

最新回答 9月 20, 2016 用户: 王孙萋萋 (462 分)  
采纳于 9月 20, 2016 用户:45°
1 喜欢 0 不喜欢
这是使用urandom的一个更简单的版本
< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo
 
使用非常有用的dd命令
dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | rev
 
你甚至可以生成一个只用左手便可以输入的密码
</dev/urandom tr -dc '12345!@#$%qwertQWERTasdfgASDFGzxcvbZXCVB' | head -c32; echo
 
 
 如果每次都使用上述某种方法,那更好的办法是将它保存为函数。如果这样做了,那么在首次运行命令之后,你便可以在任何时间只使用randpw就可以生成随机密码。或许你可以把它保存到你的~/.bashrc文件里面
randpw(){ < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo;}
 
最后这种生成随机密码的方法是最简单的。它同样也可以在安装了Cygwin的Windows下面运行。在Mac OS X下也可以运行。我敢肯定会有人抱怨这种方法生成的密码没有其它方法来的随机。但实际上如果你使用它生成的全部字符串作为密码,那这个密码就足够随机了
 
date | md5sum
最新回答 9月 20, 2016 用户: spiderman (2,436 分)  
1 喜欢 0 不喜欢
使用内嵌的/dev/urandom,并过滤掉那些日常不怎么使用的字符。这里也只输出结果的前32个字符:
< /dev/urandom tr -dc _A-Z-a-z-0-9 |head -c${1:-32};echo
 
使用openssl的随机函数
openssl rand -base64 32
 
 这种方法类似于之前的urandom,但它是反向工作的
tr -cd '[:alnum:]' < /dev/urandom | fold -w32 | head -n1;echo
 
 使用string命令,它从一个文件中输出可打印的字符串
strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 32 | tr -d '\n'; echo
最新回答 9月 20, 2016 用户: spiderman (2,436 分)  
0 喜欢 0 不喜欢

请使用SHA算法来加密日期,并输出结果的前32个字符。

最新回答 9月 20, 2016 用户: lalala666 (2,006 分)  
0 喜欢 0 不喜欢
1.date +%s | sha256sum | base64 |head -c 32 ; echo

2.< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c$(1:-32);echo;

3.openssl rand -base64 32

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

5.strings /dev/urandom | grep -o '[[:alnum;]]' | head -n 30 | tr -d '\n'; echo
最新回答 9月 20, 2016 用户: LMY (2,898 分)  
0 喜欢 0 不喜欢
使用内嵌的/dev/urandom,并过滤掉那些日常不怎么使用的字符。这里也只输出结果的前32个字符:
< /dev/urandom tr -dc _A-Z-a-z-0-9 |head -c${1:-32};echo
 
使用openssl的随机函数
openssl rand -base64 32
 
 这种方法类似于之前的urandom,但它是反向工作的
tr -cd '[:alnum:]' < /dev/urandom | fold -w32 | head -n1;echo
 
 使用string命令,它从一个文件中输出可打印的字符串
strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 32 | tr -d '\n'; echo

 

最新回答 9月 20, 2016 用户: Traxex (1,884 分)  
0 喜欢 0 不喜欢

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

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

生成结果如下:

  1. ZTNiMGM0NDI5OGZjMWMxNDlhZmJmNGM4

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

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

生成结果如下:

  1. pDj0Xwz7exD_Qb5B27BwWsM1hrF3a7cJ

3. 使用openssl的随机函数

  1. openssl rand -base64 32

生成结果如下:

  1. rYJWqJlTLAYeX3j7nCbir20h1k/0CnqLNEuNyTScfKo=

4. 这种方法类似于之前的urandom,但它是反向工作的

  1. tr -cd '[:alnum:]' < /dev/urandom | fold -w32 | head -n1;echo

生成结果如下:

  1. tpgudzF7sqtU4yyW2LVhmUQOZIQi87

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

  1. strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 32 | tr -d '\n'; echo

生成结果如下:

  1. W4v1iQtkmQ8sIDd9jxDQNpg8HPMOZ8

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

  1. < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo

生成结果如下:

  1. rMDlGSPN_bm-IZVFWz9BEi0rF-jIy6gs

7. 使用非常有用的dd命令

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

生成结果如下:

  1. 9+0RUd4U3HmSdMlgD7j0sf/r09MZFDVBS28W+pO2WcA

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

  1. </dev/urandom tr -dc '12345!@#$%qwertQWERTasdfgASDFGzxcvbZXCVB' | head -c32; echo

生成结果如下:

  1. VTG3#TR4sAgXg3Z%##WZG4ZQ@GZ$wdqF

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

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

生成结果如下:

  1. vgBX8cNo950RiykZRpPYa4BvbAvZbY_x

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

  1. date | md5sum

生成结果如下:

  1. e0d057b46a9a78346cbd94b25e574e79 -
生成结果如下:
  1. MjAxNOW5tCAwN+aciCAzMeaXpSDmmJ/mnJ/lm5sgMTc6MDA6MzYgQ1NUCg==

生成结果如下:

  1. 7c4243742aa515d45c12deca31428a95 -

 

甚至你想生成一个核弹发射密码都可以,下面是一个生成长密码的例子;

  1. ifconfig | base64

生成结果如下:

  1. ZW0xICAgICAgIExpbmsgZW5jYXA6RXRoZXJuZXQgIEhXYWRkciA3ODoyQjpDQjoyQjpCMDo5NCAg
  2. CiAgICAgICAgICBpbmV0IGFkZHI6MTkyLjE2OC4zLjUgIEJjYXN0OjE5Mi4xNjguMy4yNTUgIE1h
  3. c2s6MjU1LjI1NS4yNTUuMAogICAgICAgICAgaW5ldDYgYWRkcjogZmU4MDo6N2EyYjpjYmZmOmZl
  4. MmI6YjA5NC82NCBTY29wZTpMaW5rCiAgICAgICAgICBVUCBCUk9BRENBU1QgUlVOTklORyBNVUxU
  5. SUNBU1QgIE1UVToxNTAwICBNZXRyaWM6MQogICAgICAgICAgUlggcGFja2V0czoyMDY3NTY0IGVy
  6. cm9yczowIGRyb3BwZWQ6MCBvdmVycnVuczowIGZyYW1lOjAKICAgICAgICAgIFRYIHBhY2tldHM6
  7. ODg2NDUgZXJyb3JzOjAgZHJvcHBlZDowIG92ZXJydW5zOjAgY2FycmllcjowCiAgICAgICAgICBj
  8. b2xsaXNpb25zOjAgdHhxdWV1ZWxlbjoxMDAwIAogICAgICAgICAgUlggYnl0ZXM6MjAzNDkzNTEx
  9. ICgxOTQuMCBNaUIpICBUWCBieXRlczozMjUyNzUxNiAoMzEuMCBNaUIpCgpsbyAgICAgICAgTGlu
  10. ayBlbmNhcDpMb2NhbCBMb29wYmFjayAgCiAgICAgICAgICBpbmV0IGFkZHI6MTI3LjAuMC4xICBN
  11. YXNrOjI1NS4wLjAuMAogICAgICAgICAgaW5ldDYgYWRkcjogOjoxLzEyOCBTY29wZTpIb3N0CiAg
  12. ICAgICAgICBVUCBMT09QQkFDSyBSVU5OSU5HICBNVFU6MTY0MzYgIE1ldHJpYzoxCiAgICAgICAg
  13. ICBSWCBwYWNrZXRzOjU2OTkzMSBlcnJvcnM6MCBkcm9wcGVkOjAgb3ZlcnJ1bnM6MCBmcmFtZTow
  14. CiAgICAgICAgICBUWCBwYWNrZXRzOjU2OTkzMSBlcnJvcnM6MCBkcm9wcGVkOjAgb3ZlcnJ1bnM6
  15. MCBjYXJyaWVyOjAKICAgICAgICAgIGNvbGxpc2lvbnM6MCB0eHF1ZXVlbGVuOjAgCiAgICAgICAg
  16. ICBSWCBieXRlczozMzEzMDcxOSAoMzEuNSBNaUIpICBUWCBieXRlczozMzEzMDcxOSAoMzEuNSBN
  17. aUIpCgo=

 

最新回答 9月 20, 2016 用户: 、Whiteˉ (594 分)  
1 喜欢 0 不喜欢

http://www.jb51.net/article/76981.htm

希望对你有所帮助

最新回答 9月 20, 2016 用户: paranoid (1,648 分)  
0 喜欢 0 不喜欢
最新回答 9月 20, 2016 用户: 我好像在哪见过你 (3,976 分)  
0 喜欢 0 不喜欢
最新回答 9月 20, 2016 用户: shenme (3,438 分)  
...