其他

八种在 Linux 上生成随机密码的方法 | Linux 中国

2018-02-07 译者Sun Yongfei Linux中国
学习使用 8 种 Linux 原生命令或第三方实用程序来生成随机密码。
-- Kerneltalks

本文导航
编译自 | https://kerneltalks.com/tips-tricks/8-ways-to-generate-random-password-in-linux/ 
 作者 | Kerneltalks
 译者 | Sun Yongfei

学习使用 8 种 Linux 原生命令或第三方实用程序来生成随机密码。

在这篇文章中,我们将引导你通过几种不同的方式在 Linux 终端中生成随机密码。其中几种利用原生 Linux 命令,另外几种则利用极易在 Linux 机器上安装的第三方工具或实用程序实现。在这里我们利用像 openssldd[1]md5sumtrurandom 这样的原生命令和 mkpasswd,randpw,pwgen,spw,gpg,xkcdpass,diceware,revelation,keepaasx,passwordmaker 这样的第三方工具。

其实这些方法就是生成一些能被用作密码的随机字母字符串。随机密码可以用于新用户的密码,不管用户基数有多大,这些密码都是独一无二的。话不多说,让我们来看看 8 种不同的在 Linux 上生成随机密码的方法吧。

使用 mkpasswd 实用程序生成密码

mkpasswd 在基于 RHEL 的系统上随 expect 软件包一起安装。在基于 Debian 的系统上 mkpasswd 则在软件包 whois 中。直接安装 mkpasswd 软件包将会导致错误:

◈ RHEL 系统:软件包 mkpasswd 不可用。◈ Debian 系统:错误:无法定位软件包 mkpasswd。

所以按照上面所述安装他们的父软件包,就没问题了。

运行 mkpasswd 来获得密码

  1. root@kerneltalks# mkpasswd << on RHEL

  2. zt*hGW65c

  3. root@kerneltalks# mkpasswd teststring << on Ubuntu

  4. XnlrKxYOJ3vik

这个命令在不同的系统上表现得不一样,所以工作方式各异。你也可以通过参数来控制长度等选项,可以查阅 man 手册来探索。

使用 openssl 生成密码

几乎所有 Linux 发行版都包含 openssl。我们可以利用它的随机功能来生成可以用作密码的随机字母字符串。

  1. root@kerneltalks # openssl rand -base64 10

  2. nU9LlHO5nsuUvw==

这里我们使用 base64 编码随机函数,最后一个数字参数表示长度。

使用 urandom 生成密码

设备文件 /dev/urandom 是另一个获得随机字符串的方法。我们使用 tr 功能并裁剪输出来获得随机字符串,并把它作为密码。

  1. root@kerneltalks # strings /dev/urandom |tr -dc A-Za-z0-9 | head -c20; echo

  2. UiXtr0NAOSIkqtjK4c0X

使用 dd 命令生成密码

我们甚至可以使用 /dev/urandom 设备配合 dd 命令[1] 来获取随机字符串。

  1. root@kerneltalks# dd if=/dev/urandom bs=1 count=15|base64 -w 0

  2. 15+0 records in

  3. 15+0 records out

  4. 15 bytes (15 B) copied, 5.5484e-05 s, 270 kB/s

  5. QMsbe2XbrqAc2NmXp8D0

我们需要将结果通过 base64 编码使它能被人类可读。你可以使用数值来获取想要的长度。想要获得更简洁的输出的话,可以将“标准错误输出”重定向到 /dev/null。简洁输出的命令是:

  1. root@kerneltalks # dd if=/dev/urandom bs=1 count=15 2>/dev/null|base64 -w 0

  2. F8c3a4joS+a3BdPN9C++

使用 md5sum 生成密码

另一种获取可用作密码的随机字符串的方法是计算 MD5 校验值!校验值看起来确实像是随机字符串组合在一起,我们可以用作密码。确保你的计算源是个变量,这样的话每次运行命令时生成的校验值都不一样。比如 date !date 命令[2] 总会生成不同的输出。

  1. root@kerneltalks # date |md5sum

  2. 4d8ce5c42073c7e9ca4aeffd3d157102  -

在这里我们将 date 命令的输出通过 md5sum 得到了校验和!你也可以用 cut 命令[3] 裁剪你需要的长度。

使用 pwgen 生成密码

pwgen 软件包在类似 EPEL 软件仓库[4](LCTT 译注:企业版 Linux 附加软件包)中。pwgen 更专注于生成可发音的密码,但它们不在英语词典中,也不是纯英文的。标准发行版仓库中可能并不包含这个工具。安装这个软件包然后运行 pwgen 命令行。Boom !

  1. root@kerneltalks # pwgen

  2. thu8Iox7 ahDeeQu8 Eexoh0ai oD8oozie ooPaeD9t meeNeiW2 Eip6ieph Ooh1tiet

  3. cootad7O Gohci0vo wah9Thoh Ohh3Ziur Ao1thoma ojoo6aeW Oochai4v ialaiLo5

  4. aic2OaDa iexieQu8 Aesoh4Ie Eixou9ph ShiKoh0i uThohth7 taaN3fuu Iege0aeZ

  5. cah3zaiW Eephei0m AhTh8guo xah1Shoo uh8Iengo aifeev4E zoo4ohHa fieDei6c

  6. aorieP7k ahna9AKe uveeX7Hi Ohji5pho AigheV7u Akee9fae aeWeiW4a tiex8Oht

你的终端会呈现出一个密码列表!你还想要什么呢?好吧。你还想再仔细探索的话, pwgen还有很多自定义选项,这些都可以在 man 手册里查阅到。

使用 gpg 工具生成密码

GPG 是一个遵循 OpenPGP 标准的加密及签名工具。大部分 gpg 工具都预先被安装好了(至少在我的 RHEL7 上是这样)。但如果没有的话你可以寻找 gpg 或 gpg2 软件包并安装[5]它。

使用下面的命令以从 gpg 工具生成密码。

  1. root@kerneltalks # gpg --gen-random --armor 1 12

  2. mL8i+PKZ3IuN6a7a

这里我们传了生成随机字节序列选项(--gen-random),质量为 1(第一个参数),次数 12 (第二个参数)。选项 --armor 保证以 base64 编码输出。

使用 xkcdpass 生成密码

著名的极客幽默网站 xkcd[6],发表了一篇非常有趣的文章,是关于好记但又复杂的密码的。你可以在这里[7]阅读。所以 xkcdpass 工具就受这篇文章启发,做了这样的工作!这是一个 Python 软件包,可以在这里[8]的 Python 的官网上找到它。

所有的安装使用说明都在上面那个页面提及了。这里是安装步骤和我的测试 RHEL 服务器的输出,以供参考。

  1. root@kerneltalks # wget https://pypi.python.org/packages/b4/d7/3253bd2964390e034cf0bba227db96d94de361454530dc056d8c1c096abc/xkcdpass-1.14.3.tar.gz#md5=5f15d52f1d36207b07391f7a25c7965f

  2. --2018-01-23 19:09:17--  https://pypi.python.org/packages/b4/d7/3253bd2964390e034cf0bba227db96d94de361454530dc056d8c1c096abc/xkcdpass-1.14.3.tar.gz

  3. Resolving pypi.python.org (pypi.python.org)... 151.101.32.223, 2a04:4e42:8::223

  4. Connecting to pypi.python.org (pypi.python.org)|151.101.32.223|:443... connected.

  5. HTTP request sent, awaiting response... 200 OK

  6. Length: 871848 (851K) [binary/octet-stream]

  7. Saving to: xkcdpass-1.14.3.tar.gz

  8. 100%[==============================================================================================================================>] 871,848     --.-K/s   in 0.01s

  9. 2018-01-23 19:09:17 (63.9 MB/s) - xkcdpass-1.14.3.tar.gz saved [871848/871848]

  10. root@kerneltalks # tar -xvf xkcdpass-1.14.3.tar.gz

  11. xkcdpass-1.14.3/

  12. xkcdpass-1.14.3/examples/

  13. xkcdpass-1.14.3/examples/example_import.py

  14. xkcdpass-1.14.3/examples/example_json.py

  15. xkcdpass-1.14.3/examples/example_postprocess.py

  16. xkcdpass-1.14.3/LICENSE.BSD

  17. xkcdpass-1.14.3/MANIFEST.in

  18. xkcdpass-1.14.3/PKG-INFO

  19. xkcdpass-1.14.3/README.rst

  20. xkcdpass-1.14.3/setup.cfg

  21. xkcdpass-1.14.3/setup.py

  22. xkcdpass-1.14.3/tests/

  23. xkcdpass-1.14.3/tests/test_list.txt

  24. xkcdpass-1.14.3/tests/test_xkcdpass.py

  25. xkcdpass-1.14.3/tests/__init__.py

  26. xkcdpass-1.14.3/xkcdpass/

  27. xkcdpass-1.14.3/xkcdpass/static/

  28. xkcdpass-1.14.3/xkcdpass/static/eff-long

  29. xkcdpass-1.14.3/xkcdpass/static/eff-short

  30. xkcdpass-1.14.3/xkcdpass/static/eff-special

  31. xkcdpass-1.14.3/xkcdpass/static/fin-kotus

  32. xkcdpass-1.14.3/xkcdpass/static/ita-wiki

  33. xkcdpass-1.14.3/xkcdpass/static/legacy

  34. xkcdpass-1.14.3/xkcdpass/static/spa-mich

  35. xkcdpass-1.14.3/xkcdpass/xkcd_password.py

  36. xkcdpass-1.14.3/xkcdpass/__init__.py

  37. xkcdpass-1.14.3/xkcdpass.1

  38. xkcdpass-1.14.3/xkcdpass.egg-info/

  39. xkcdpass-1.14.3/xkcdpass.egg-info/dependency_links.txt

  40. xkcdpass-1.14.3/xkcdpass.egg-info/entry_points.txt

  41. xkcdpass-1.14.3/xkcdpass.egg-info/not-zip-safe

  42. xkcdpass-1.14.3/xkcdpass.egg-info/PKG-INFO

  43. xkcdpass-1.14.3/xkcdpass.egg-info/SOURCES.txt

  44. xkcdpass-1.14.3/xkcdpass.egg-info/top_level.txt

  45. root@kerneltalks # cd xkcdpass-1.14.3

  46. root@kerneltalks # python setup.py install

  47. running install

  48. running bdist_egg

  49. running egg_info

  50. writing xkcdpass.egg-info/PKG-INFO

  51. writing top-level names to xkcdpass.egg-info/top_level.txt

  52. writing dependency_links to xkcdpass.egg-info/dependency_links.txt

  53. writing entry points to xkcdpass.egg-info/entry_points.txt

  54. reading manifest file 'xkcdpass.egg-info/SOURCES.txt'

  55. reading manifest template 'MANIFEST.in'

  56. writing manifest file 'xkcdpass.egg-info/SOURCES.txt'

  57. installing library code to build/bdist.linux-x86_64/egg

  58. running install_lib

  59. running build_py

  60. creating build

  61. creating build/lib

  62. creating build/lib/xkcdpass

  63. copying xkcdpass/xkcd_password.py -> build/lib/xkcdpass

  64. copying xkcdpass/__init__.py -> build/lib/xkcdpass

  65. creating build/lib/xkcdpass/static

  66. copying xkcdpass/static/eff-long -> build/lib/xkcdpass/static

  67. copying xkcdpass/static/eff-short -> build/lib/xkcdpass/static

  68. copying xkcdpass/static/eff-special -> build/lib/xkcdpass/static

  69. copying xkcdpass/static/fin-kotus -> build/lib/xkcdpass/static

  70. copying xkcdpass/static/ita-wiki -> build/lib/xkcdpass/static

  71. copying xkcdpass/static/legacy -> build/lib/xkcdpass/static

  72. copying xkcdpass/static/spa-mich -> build/lib/xkcdpass/static

  73. creating build/bdist.linux-x86_64

  74. creating build/bdist.linux-x86_64/egg

  75. creating build/bdist.linux-x86_64/egg/xkcdpass

  76. copying build/lib/xkcdpass/xkcd_password.py -> build/bdist.linux-x86_64/egg/xkcdpass

  77. copying build/lib/xkcdpass/__init__.py -> build/bdist.linux-x86_64/egg/xkcdpass

  78. creating build/bdist.linux-x86_64/egg/xkcdpass/static

  79. copying build/lib/xkcdpass/static/eff-long -> build/bdist.linux-x86_64/egg/xkcdpass/static

  80. copying build/lib/xkcdpass/static/eff-short -> build/bdist.linux-x86_64/egg/xkcdpass/static

  81. copying build/lib/xkcdpass/static/eff-special -> build/bdist.linux-x86_64/egg/xkcdpass/static

  82. copying build/lib/xkcdpass/static/fin-kotus -> build/bdist.linux-x86_64/egg/xkcdpass/static

  83. copying build/lib/xkcdpass/static/ita-wiki -> build/bdist.linux-x86_64/egg/xkcdpass/static

  84. copying build/lib/xkcdpass/static/legacy -> build/bdist.linux-x86_64/egg/xkcdpass/static

  85. copying build/lib/xkcdpass/static/spa-mich -> build/bdist.linux-x86_64/egg/xkcdpass/static

  86. byte-compiling build/bdist.linux-x86_64/egg/xkcdpass/xkcd_password.py to xkcd_password.pyc

  87. byte-compiling build/bdist.linux-x86_64/egg/xkcdpass/__init__.py to __init__.pyc

  88. creating build/bdist.linux-x86_64/egg/EGG-INFO

  89. copying xkcdpass.egg-info/PKG-INFO -> build/bdist.linux-x86_64/egg/EGG-INFO

  90. copying xkcdpass.egg-info/SOURCES.txt -> build/bdist.linux-x86_64/egg/EGG-INFO

  91. copying xkcdpass.egg-info/dependency_links.txt -> build/bdist.linux-x86_64/egg/EGG-INFO

  92. copying xkcdpass.egg-info/entry_points.txt -> build/bdist.linux-x86_64/egg/EGG-INFO

  93. copying xkcdpass.egg-info/not-zip-safe -> build/bdist.linux-x86_64/egg/EGG-INFO

  94. copying xkcdpass.egg-info/top_level.txt -> build/bdist.linux-x86_64/egg/EGG-INFO

  95. creating dist

  96. creating 'dist/xkcdpass-1.14.3-py2.7.egg' and adding 'build/bdist.linux-x86_64/egg' to it

  97. removing 'build/bdist.linux-x86_64/egg' (and everything under it)

  98. Processing xkcdpass-1.14.3-py2.7.egg

  99. creating /usr/lib/python2.7/site-packages/xkcdpass-1.14.3-py2.7.egg

  100. Extracting xkcdpass-1.14.3-py2.7.egg to /usr/lib/python2.7/site-packages

  101. Adding xkcdpass 1.14.3 to easy-install.pth file

  102. Installing xkcdpass script to /usr/bin

  103. Installed /usr/lib/python2.7/site-packages/xkcdpass-1.14.3-py2.7.egg

  104. Processing dependencies for xkcdpass==1.14.3

  105. Finished processing dependencies for xkcdpass==1.14.3

现在运行 xkcdpass 命令,将会随机给出你几个像下面这样的字典单词:

  1. root@kerneltalks # xkcdpass

  2. broadside unpadded osmosis statistic cosmetics lugged

你可以用这些单词作为其他命令,比如 md5sum 的输入,来获取随机密码(就像下面这样),甚至你也可以用每个单词的第 N 个字母来生成你的密码!

  1. root@kerneltalks # xkcdpass |md5sum

  2. 45f2ec9b3ca980c7afbd100268c74819  -

  3. root@kerneltalks # xkcdpass |md5sum

  4. ad79546e8350744845c001d8836f2ff2  -

或者你甚至可以把所有单词串在一起作为一个超长的密码,不仅非常好记,也不容易被电脑程序攻破。

Linux 上还有像 Diceware[9]、 KeePassX[10]、 Revelation[11]、 PasswordMaker[12]这样的工具,也可以考虑用来生成强随机密码。


via: https://kerneltalks.com/tips-tricks/8-ways-to-generate-random-password-in-linux/

作者:kerneltalks[14] 译者:heart4lor 校对:Locez

本文由 LCTT 原创编译,Linux中国 荣誉推出

LCTT 译者
Sun Yongfei(heart4lor) 🌟 🌟共计翻译:2 篇贡献时间:3 天

推荐文章

< 左右滑动查看相关文章 >

点击图片、输入文章 ID 或识别二维码直达




您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存