博客
关于我
用Python写密码强度测试程序!原理居然就是这样!
阅读量:238 次
发布时间:2019-03-01

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

概述

小时候申请QQ账号时,经常被密码设置难住,设置高强度密码咋就这么难呢。今天,就着手写一个判断密码强度的程序。

通常密码设置有以下三点要求:1、字符长度需在8-16位之间;2、不能使用空格、中文字符;3、至少含有数字/字母/字符2种组合。另外,针对密码强度,笔者就不设置太复杂的规则了,在满足上述3个条件的基础上,密码有数字/字母/字符2种组合为密码强度中,有数字/字母/字符3种组合为密码强度高。

下面就开始吧= ^ =

思路

1、首先可以分别编写三个函数,分别判断密码中的字符类型(数字/字母/字符);

2、然后编写一个判断合法性程序,判断密码长度、字符类型以及组合形式是否合法;
3、最后编写主程序,按密码要求思路调用上述1和2中函数,即可完成密码强度判断

代码解析

1、数字判断

def check_number(password):     for c in password:        if c.isnumeric(): # str.isnumeric()用于判断字符串是否只包含数字字符            return True            break # 遍历密码,遇到数字字符及函数返回True并结束遍历;若遍历完所有字符无数字字符,则函数返回为None(假)

2、字母判断

def check_letter(password):    for c in password:        if 'a'<=c<='z' or 'A'<=c<='Z':            return True            break

3、字符判断

def check_mark(password):    for c in password:        if not (c.isnumeric() or 'a'<=c<='z' or 'A'<=c<='Z'):            return True            break

4、合法性判断

def check_legal(password):    if len(password)<8 or len(password)>16:        print('长度需为8-16个字符,请重新输入。')        return False    else:        for i in password:            if 0x4e00<=ord(i)<=0x9fa5 or ord(i)==0x20: # Ox4e00等十六进制数分别为中文字符和空格的Unicode编码                print('不能使用空格、中文,请重新输入。') # ord(c)用于返回一个字符c的Unicode数值                return False        else:            key = 0            key += 1 if check_number(password) else 0            key += 1 if check_letter(password) else 0            key += 1 if check_mark(password) else 0            if key >= 2:                return True            else:                print('至少含数字/字母/字符2种组合,请重新输入。')                return False

5、主程序

def main():    while True:        password = input('请输入密码:')        if check_legal(password):            strength_level = 0            strength_level += 1 if check_number(password) else 0            strength_level += 1 if check_letter(password) else 0            strength_level += 1 if check_mark(password) else 0            if strength_level == 2:                print('密码设置成功!'+'*'*10+'强度等级中'+'*'*10)                break            else:                print('密码设置成功!'+'*'*10+'强度等级高'+'*'*10)                break                    else:            continue

完整代码、效果展示

def check_number(password):    for c in password:        if c.isnumeric():            return True            breakdef check_letter(password):    for c in password:        if 'a'<=c<='z' or 'A'<=c<='Z':            return True            breakdef check_mark(password):    for c in password:        if not (c.isnumeric() or 'a'<=c<='z' or 'A'<=c<='Z'):            return True            breakdef check_legal(password):    if len(password)<8 or len(password)>16:        print('长度需为8-16个字符,请重新输入。')        return False    else:        for i in password:            if 0x4e00<=ord(i)<=0x9fa5 or ord(i)==0x20: # Ox4e00等十六进制数分别为中文字符和空格的Unicode编码                print('不能使用空格、中文,请重新输入。')                return False        else:            key = 0            key += 1 if check_number(password) else 0            key += 1 if check_letter(password) else 0            key += 1 if check_mark(password) else 0            if key >= 2:                return True            else:                print('至少含数字/字母/字符2种组合,请重新输入。')                return False          def main():    while True:        password = input('请输入密码:')        if check_legal(password):            strength_level = 0            strength_level += 1 if check_number(password) else 0            strength_level += 1 if check_letter(password) else 0            strength_level += 1 if check_mark(password) else 0            if strength_level == 2:                print('密码设置成功!'+'*'*10+'强度等级中'+'*'*10)                break            else:                print('密码设置成功!'+'*'*10+'强度等级高'+'*'*10)                break                    else:            continueif __name__ == '__main__':    main()

代码量很少,如果需要源码的可加下我的交流群:1136192749

 

 

转载地址:http://wigp.baihongyu.com/

你可能感兴趣的文章
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>