用shell脚本和python脚本编写一个获取随机密码的代码

shell
方法一
urandom版本

#!/bin/bash
# Author:tanbensong
# /dev/urandom 文件是Linux内置的随机设备文件
# cat /dev/urandom 可以看看里面的内容,按Ctrl+C退出查看
# 查看该文件内容后,发现内容有些太随机,包括很多特殊符号,我们需要的密码不希望使用这些符号
# tr -dc '_A-Za-z0-9' </dev/urandom
# 该命令可以将随机文件中其他的字符删除,仅保留大小写字母,数字,下划线,但是内容还是太多
# 我们可以继续将优化好的内容通过管道传递给 head 命令,在大量数据中仅显示你所需要的位数

read -p "请输入密码位数,1代表1位:" pass

# 注意 A 前面有个下划线
tr -dc '_A-Za-z0-9' </dev/urandom | head -c $pass

方法二
子串截取版本

#!/bin/bash
# Author:tanbensong
# 设置变量 key,存储密码的所有可能性(密码库),如果还需要其他字符请自行添加其他密码字符
# 使用$#统计密码库的长度

key="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
num=${#key}

# 设置初始密码为空
pass=''

# 循环 8 次,生成 8 位随机密码
# 每次都是随机数对密码库的长度取余,确保提取的密码字符不超过密码库的长度
# 每次循环提取一位随机密码,并将该随机密码追加到 pass 变量的最后

for i in {1..8}
do
        index=$[RANDOM%num]
        pass=$pass${key:$index:1}
done
echo $pass

python

#!/usr/bin/env python
# coding:utf-8
# Author:tanbengsong

import string
import random

passwd=''
passchs=string.letters + string.digits

for i in range(8):
    passwd += random.choice(passchs)

print passwd
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值