python实现密码破解

1.排列

itertools.permutations(iterable,n)

  • 参数一:要排列的序列,
  • 参数二:要选取的个数

返回的是一个迭代对象,迭代器中的每一个元素都是一个元组

 import itertools
 # 概念:从n个不同元素中取出m(m≤n)个元素,按照一定的顺序排成一列,
 # 叫做从n个元素中取出m个元素的一个排列(Arrangement)。
 # 特别地,当m=n时,这个排列被称作全排列(Permutation)
  '''
1 2 3 4
 假设从中取出3个数字
123
 132
 213
 231
 321
 312
'''
#需求:从[1,2,3,4]4个数中随机取出3个数进行排列
 mylist = list(itertools.permutations([1,2,3,4], 3))
 print(mylist)
 print(len(mylist))

 '''
 规律总结:

 4 - 3   24
 4 - 2   12
 4 - 1   4

 排列的可能性次数:n! / (n-m)!

 '''

2.组合

itertools.combinations(iterable,n)

  • 参数一:可迭代对象
  • 参数二:要选取的个数

返回值:返回一二迭代器,迭代器中的每一个元素都是一个元组

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import itertools

# 概念:从m个不同的元素中,任取n(n≤m)个元素为一组,
# 叫作从m个不同元素中取出n个元素的进行组合
'''
1 2 3 4 5 中选4个数的组合方式有几种?
'''
mylist = list(itertools.combinations([1,2,3,4,5], 4))
print(mylist)
print(len(mylist))

'''

规律总结:

m   n
5 - 5   1
5 - 4   5
5 - 3   10
5 - 2   10

5120/120(m-n)!
120/24(m-n)!
120/6(m-n)!
m!/(n!x(m-n)!)
'''

3.排列组合

itertools.product(iterable,repeat=1)
参数一:可迭代对象,参数二:重复的次数,默认为1

import itertools

'''
_ _ _ _ _
'''

mylist = list(itertools.product("0123456789QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm", repeat=6))
#可以尝试10,有可能电脑会卡住
#多线程也不行,电脑内存不够,咋处理都白搭
#print(mylist)
print(len(mylist))

扩展:现在但凡涉及到密码,一般都会进行加密处理,常用的加密方式有MD5,RSA,DES等

4.疯狂破解密码

伤敌一千自损一万的破解方式

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import time
import itertools
#mylist = list(itertools.product("0123456789", repeat=10))
passwd = ("".join(x) for x in itertools.product("0123456789QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm", repeat=6))
#print(mylist)
#print(len(mylist))
while True:
    #先直接实现,然后再添加异常
    try:
        str = next(passwd)
        time.sleep(0.5)
        print(str)
    except StopIteration as e:
        break
posted @ 2022-10-07 20:31  I'm_江河湖海  阅读(104)  评论(0编辑  收藏  举报