”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 用 Python 构建密码强度检查器

用 Python 构建密码强度检查器

发布于2024-11-01
浏览:664

大家好,欢迎来到今天的教程。今天,我们将使用 Python 构建一个简单的密码强度检查器。我们将逐步解释该代码的工作原理,并提供有关如何改进密码的提示。

为什么密码强度很重要?

弱密码会让黑客更容易通过各种方法猜测或破解,从而使您的个人信息面临风险。强密码是:

  • 足够长(至少12个字符)
  • 混合使用字母(大写和小写)、数字和特殊字符
  • 避免常见或可预测的单词

让我们开始构建一个根据这些规则评估密码强度的工具。

设置您的环境

在我们开始编码之前,请确保您的计算机上安装了 Python。

创建一个新的 Python 文件,您将在其中编写代码。另外,下载包含最常见密码的文件(稍后我们将详细介绍)并将该文件保存在与该项目的 Python 文件相同的目录中。

导入必要的库

import string

字符串模块提供了有用的常量来检查字符类型,如大写字母、数字和特殊字符。

检查常用密码

def check_common_password(password):
    with open('common-password.txt', 'r') as f:
        common = f.read().splitlines()
    if password in common:
        return True
    return False

此函数检查给定的密码是否在常用密码列表中。

  • 它会打开我们之前下载的名为“common-password.txt”的文件。
  • 它将该文件中的所有密码读取到列表中。
  • 如果输入的密码在此列表中,则返回 True(意味着它是通用密码,因此是弱密码)。
  • 否则返回False。

为什么这很重要?许多黑客从尝试通用密码开始,因此使用一个密码会让您的帐户非常容易受到攻击。

评估密码强度

def password_strength(password):
    score = 0
    length = len(password)

    upper_case = any(c.isupper() for c in password)
    lower_case = any(c.islower() for c in password)
    special = any(c in string.punctuation for c in password)
    digits = any(c.isdigit() for c in password)

    characters = [upper_case, lower_case, special, digits]

    if length > 8:
        score  = 1
    if length > 12:
        score  = 1
    if length > 17:
        score  = 1
    if length > 20:
        score  = 1

    score  = sum(characters) - 1

    if score 



此函数根据多个标准评估密码的强度。

  • 密码长度超过 8、12、17 和 20 个字符将获得积分。
  • 它检查是否存在大写字母、小写字母、特殊字符和数字。

评分是如何进行的?

  1. 分数从 0 开始。
  2. 每通过一个长度阈值就加 1 分。
  3. 使用的每种字符(大写、小写、特殊、数字)加 1 分,减 1。
  4. 根据最终得分,将密码分类为“弱”、“还好”、“好”或“强”。

向用户提供反馈

def feedback(password):
    if check_common_password(password):
        return "Password was found in a common list. Score: 0/7"

    strength, score = password_strength(password)

    feedback = f"Password strength: {strength} (Score: {score}/7)\n"

    if score 



该功能结合了前两个功能,提供全面的反馈。

  • 它首先检查密码是否通用。如果是这样,它会立即返回警告。
  • 如果密码不常见,则会评估其强度。
  • 提供强度等级和分数。
  • 如果密码较弱(分数

主程序

password = input("Enter the password: ")
print(feedback(password))

最后一部分只是要求用户输入密码,然后打印反馈。

行动计划

Building a Password Strength Checker in Python

结论

创建强密码是维护在线安全的重要组成部分,使用此工具,您可以轻松评估密码的安全性。这个简单的程序演示了如何将基本的 Python 编程与网络安全原则相结合来解决现实世界的问题。

随意尝试代码并添加更多功能。

快乐编码,保持安全!

版本声明 本文转载于:https://dev.to/immah/building-a-password-strength-checker-in-python-47om?1如有侵犯,请联系[email protected]删除
最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3