博客
关于我
用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/

你可能感兴趣的文章
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>