在我们做渗透测试的过程中,常常会遇到需要暴力破解的场景,对于暴力破解,关键在于拥有一个好的字典,拥有一个准确且命中率高的字典,其效果远比拥有一个跑得快的暴力破解器来的实在。所以,拥有一个好的密码生成器是十分重要的。
密码生成器是指生成随机、复杂且安全的密码的工具。密码生成器能够根据用户的要求生成具有一定长度和复杂度的密码,以增加密码的安全性,减少被猜测或破解的可能性。
密码生成器通常能够生成包含大写字母、小写字母、数字和符号等多种字符组成的密码。一些密码生成器还可以根据用户的需求,生成易记、易读但仍具有一定安全性的密码。
使用密码生成器可以帮助用户避免使用过于简单、常见或易被猜测的密码,提高账户或系统的安全性。为了增加密码的安全性,使用密码生成器生成密码后,用户还应当定期更改密码,并避免在多个账户中使用同一密码。
下面我们通过本文来学习如何通过python来开发一个密码生成器,密码生成器开发的核心思想是创建一个能够生成强密码的算法和机制。这个算法和机制应该能够满足以下几个关键要素:
密码生成器的实现代码如下所示,将其保存为password_dict.py文件:
#!/usr/bin/env python
from argparse import ArgumentParser
import string
import random
import secrets
passwords = []
def SetParser():
parser = ArgumentParser(
prog = "密码生成器",
description="这是一个密码生成器,可以生成任何形式的密码"
)
parser.add_argument("-l","--lowercase",default=0,help="密码中包含小写字符的位数",type=int)
parser