博客
关于我
用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中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>