博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用Linux系统生成随机密码的8种方法
阅读量:5094 次
发布时间:2019-06-13

本文共 2027 字,大约阅读时间需要 6 分钟。

Linux操作系统的一大优点是对于同样一件事情,你可以使用高达数百种方法来实现它。例如,你可以通过数十种方法来生成随机密码。本文将介绍生成随机密码的十种方法。

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

[root@kafka60 shell]# date +%s |sha256sum |base64 |head -c 10 ;echoYTc4Mjk0Yj

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

1 #tr参数  2 -c或——complerment:取代所有不属于第一字符集的字符; 3 -d或——delete:删除所有属于第一字符集的字符; 4 1.生成10个小写字母 5 [root@kafka60 shell]# < /dev/urandom tr -dc a-z|head -c ${
1:-10};echo 6 iprnfrqlhr 7 2.生成10个大写字母 8 [root@kafka60 shell]# < /dev/urandom tr -dc A-Z|head -c ${
1:-10};echo 9 PSKSFZYQPH10 3.生成10个数字11 [root@kafka60 shell]# < /dev/urandom tr -dc 0-9|head -c ${
1:-10};echo12 734138459213 4.生成10个数字和大写字母的组合字符串14 [root@kafka60 shell]# < /dev/urandom tr -dc 0-9-A-Z|head -c ${
1:-10};echo15 M6HP4LHTNJ16 5.生成10个随机字符(包含数字,大写字母,小写字母)17 [root@kafka60 shell]# < /dev/urandom tr -dc 0-9-A-Z-a-z|head -c ${
1:-10};echo18 79JUYcjrjx19 6.生成10个随机字符(包含数字,大写字母,小写字母)20 [root@kafka60 shell]# < /dev/urandom tr -dc 0-9-A-Z-a-z-|head -c ${
1:-10};echo21 JdOi4TMmZD22 7.生成10个随机字符(包含数字,大写字母,小写字母,特殊字符)23 [root@kafka60 shell]# < /dev/urandom tr -dc 0-9-A-Z-a-z-/|head -c ${
1:-10};echo24 s5-yTgMa8G

3. 使用openssl的随机函数

[root@kafka60 shell]# openssl rand -base64 106kf9CHiiRgiSVQ==[root@kafka60 shell]# openssl rand -base64 10|tr A-Z a-z1ivhbhsrvjsfsa==[root@kafka60 shell]# openssl rand -base64 32|tr A-Z a-z|cut -c 1-10hbxd/42tag

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

[root@kafka60 shell]# tr -cd '[:alnum:]' 

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

[root@kafka60 shell]# strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 32 | tr -d '\n'; echozFSi9lMfBe6igWotELx0O85sx1hL2ux7

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

[root@kafka60 shell]# 

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

[root@kafka60 shell]# dd if=/dev/urandom bs=1 count=32 2>/dev/null | base64 -w 0 | rev | cut -b 2- | revT5cfmBaTX1xcUo+aa4wK+XKF/ydh1VqovEyl8oCxmsw[root@kafka60 shell]# dd if=/dev/urandom bs=1 count=10 2>/dev/null | base64 -w 0 | rev | cut -b 2- | revKQqr7OPAoaHsIg=

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

[root@kafka60 shell]# 

转载于:https://www.cnblogs.com/dadonggg/p/8477655.html

你可能感兴趣的文章
overflow 属性
查看>>
Mychael原创题 洛谷T23923 Mychaelの水题 【题解】
查看>>
Objective-C 协议(protocol)
查看>>
Android自定义进度条
查看>>
java虚拟机深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
查看>>
struts返回对象json格式数据
查看>>
[[UIScreen mainScreen] bounds] 返回的屏幕尺寸不对
查看>>
python基础_格式化输出(%用法和format用法)
查看>>
前端面试题之手写事件模型及事件代理/委托
查看>>
python 自动回收机制
查看>>
11月17日站立会议内容
查看>>
后端图片上传
查看>>
ubuntu编译运行xv6
查看>>
02-Mysql数据库----初识
查看>>
SqlServer中union 和 union all的区别
查看>>
C#条件编译,发布多平台和多种选择性的项目
查看>>
python 笔记数据类型
查看>>
如何用php开启企业微信开发的回调模式
查看>>
UAC在注册表中的对应位置
查看>>
机器为什么可以学习(2)---一般化理论
查看>>