鱼C论坛

 找回密码
 立即注册
查看: 4718|回复: 8

关于“第14讲作业”密码复杂度验证,漏洞

[复制链接]
发表于 2015-11-19 16:10:08 | 显示全部楼层 |阅读模式
4鱼币
本帖最后由 ~风介~ 于 2015-11-19 21:35 编辑

# 密码安全性检查代码
#
# 低级密码要求:
#   1. 密码由单纯的数字或字母组成
#   2. 密码长度小于等于8位
#
# 中级密码要求:
#   1. 密码必须由数字、字母或特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|\)任意两种组合
#   2. 密码长度不能低于8位
#
# 高级密码要求:
#   1. 密码必须由数字、字母及特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|\)三种组合
#   2. 密码只能由字母开头
#   3. 密码长度不能低于16位

  1. symbols = r'''`!@#$%^&*()_+-=/*{}[]\|'";:/?,.<>'''
  2. chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
  3. nums = '0123456789'

  4. passwd = input('请输入需要检查的密码组合:')

  5. # 判断长度
  6. length = len(passwd)

  7. while (passwd.isspace() or length == 0) :
  8.     passwd = input("您输入的密码为空(或空格),请重新输入:")

  9. if length <= 8:
  10.     flag_len = 1
  11. elif 8 < length < 16:
  12.     flag_len = 2
  13. else:
  14.     flag_len = 3

  15. flag_con = 0

  16. # 判断是否包含特殊字符
  17. for each in passwd:
  18.     if each in symbols:
  19.         flag_con += 1
  20.         break
  21.    
  22. # 判断是否包含字母
  23. for each in passwd:
  24.     if each in chars:
  25.         flag_con += 1
  26.         break

  27. # 判断是否包含数字
  28. for each in passwd:
  29.     if each in nums:
  30.         flag_con += 1
  31.         break   

  32. # 打印结果
  33. while 1 :
  34.     print("您的密码安全级别评定为:", end='')
  35.     if flag_len == 1 or flag_con == 1 :
  36.         print("低")
  37.     elif flag_len == 2 or flag_con == 2 :
  38.         print("中")
  39.     else :
  40.         print("高")
  41.         print("请继续保持")
  42.         break

  43.     print("请按以下方式提升您的密码安全级别:\n\
  44.     \t1. 密码必须由数字、字母及特殊字符三种组合\n\
  45.     \t2. 密码只能由字母开头\n\
  46.     \t3. 密码长度不能低于16位'")
  47.     break
复制代码



这个貌似没有考虑 :8位以上的纯特殊字符

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-11-19 21:36:09 | 显示全部楼层
感觉楼主说的不是很明白的样子~
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-11-20 02:25:14 | 显示全部楼层
  1. >>>
  2. 请输入需要检查的密码组合:%%%%%%%%%
  3. 您的密码安全级别评定为:低
  4. 请按以下方式提升您的密码安全级别:
  5.             1. 密码必须由数字、字母及特殊字符三种组合
  6.             2. 密码只能由字母开头
  7.             3. 密码长度不能低于16位'
  8. >>>
复制代码


八位纯特殊字符应该与纯数字或纯字母同等级:低。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-20 13:41:57 | 显示全部楼层
感谢各位回答,应该是需求上多加一条 纯特殊字符为低级 “# 低级密码要求:
#   1. 密码由单纯的数字或字母组成
#   2. 密码长度小于等于8位”
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-11-26 10:10:21 | 显示全部楼层
感还是感觉有点模糊
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-12-2 12:40:39 | 显示全部楼层
确实有点
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

头像被屏蔽
发表于 2016-1-28 08:27:58 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-8-7 13:46:13 | 显示全部楼层
顶3楼
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-8-8 11:02:21 | 显示全部楼层
这个题我考虑了好长时间,感觉前后有矛盾
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-2-18 09:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表