鱼C论坛

 找回密码
 立即注册
查看: 929|回复: 3

py十四讲密码安全性

[复制链接]
发表于 2019-3-17 09:35:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x

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

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

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

# 判断长度
length = len(passwd)

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

if length <= 8:
    flag_len = 1
elif 8 < length < 16:
    flag_len = 2
else:
    flag_len = 3

flag_con = 0

# 判断是否包含特殊字符
for each in passwd:
    if each in symbols:
        flag_con += 1
        break
   
# 判断是否包含字母
for each in passwd:
    if each in chars:
        flag_con += 1
        break

# 判断是否包含数字
for each in passwd:
    if each in nums:
        flag_con += 1
        break   

# 打印结果
while 1 :
    print("您的密码安全级别评定为:", end='')
    if flag_len == 1 or flag_con == 1 :
        print("低")
    elif flag_len == 3 and flag_con == 3 and (passwd[0] in chars):
        print("高")
        print("请继续保持")
        break
    else:
        print("中")

    print("请按以下方式提升您的密码安全级别:\n\
    \t1. 密码必须由数字、字母及特殊字符三种组合\n\
    \t2. 密码只能由字母开头\n\
    \t3. 密码长度不能低于16位")
    break
然后我的问题是,低级密码的要求不是只有数字或字母组成嘛,但是这个代码写的就是如果我全写特殊字符,显示也是低级密码??
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-3-17 09:41:48 | 显示全部楼层
很明显  单纯的特殊字符组成的密码 也属于低级密码(按照这篇代码的逻辑)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-17 10:06:46 | 显示全部楼层
测试一下不就知道了嘛,代码都要有了,怎么就不会调试呢。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-17 13:39:53 | 显示全部楼层
  1. def sum(b , n):
  2.     sum = 0
  3.     for i in range(n):
  4.         sum += b ** (i + 1)
  5.     return sum

  6. if __name__ == '__main__':
  7.     a = 26 + 10 + 28                # 密码由字母 + 数字 + 特殊符号构成
  8.     b = 28                          # 密码由特殊符号构成
  9.     print sum(a , 8) / sum(b , 8)   # 密码同样由 8 个字符构成
复制代码

        运行这个代码便可以知道,使用 字母 + 数字 + 特殊字符 构成的 8 个字符密码的组合数量是单纯使用 特殊字符 构成 8 个字符密码组合数量的 729 倍,也就是说,同样采用暴力(枚举)的方式破解,如果前者需要 729 小时(30 天),那么,后者只需要 1 小时,这就是区别,也就是单纯使用特殊符号构成密码会被评价为 '低级密码' 的真正原因。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-14 15:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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