2024年Python最新百分之99的人都不知道的Python爆破ZIP文件,2024年最新2024国内知名大厂Python岗面经

最后

🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

图片

2:修改的第一段代码

大概位置在1374行

if flags & 0x800:

UTF-8 file names extension

filename = filename.decode(‘utf-8’)

else:

Historical ZIP filename encoding

filename = filename.decode(‘gbk’) # 把cp437修改为gbk

3:修改的第2段代码

大概在1553行

这里也是与解决办法2的链接中不一致的地方。if语句的内容不一样,可能是zipfile升级的缘故

if fheader[_FH_GENERAL_PURPOSE_FLAG_BITS] & 0x800:

UTF-8 filename

fname_str = fname.decode(“utf-8”)

else:

fname_str = fname.decode(“gbk”) # 把原来的cp437更改为gbk

图片

4:保存退出即可

单线程纯数字爆破

========

需要指定一下第6行(压缩包的位置),第20行(密码区间)

import zipfile

import os

import time

import sys

os.chdir(r’C:\Users\asuka\Desktop\123’)

start_time = time.time()

获取zip文件

def get_zipfile():

files = os.listdir()

for file in files:

if file.endswith(‘.zip’):

return file

用来提取zip文件

def extract():

file = get_zipfile()

zfile = zipfile.ZipFile(file) # 读取压缩文件

for num in range(1, 1000000): # 设置数字密码区间

try:

pwd = str(num)

zfile.extractall(path=‘.’, pwd=pwd.encode(‘utf-8’))

print(‘解压密码是:’, pwd)

end_time = time.time()

print(‘单线程破解压缩包花了%s秒’ % (end_time - start_time))

sys.exit(0) # 让程序在得到结果后,就停止运行,正常退出

except Exception as e:

pass

if name == “main”:

extract()

单线程数字字母爆破

=========

脚本默认工作在脚本所在的路径,如需更改,请手动修改第49

import zipfile

import time

import sys

import random

import os

class MyIter(object):

word = “abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ” # 原始的密码本

def init(self, min_len, max_len): # 迭代器实现初始方法,传入参数

下面的if-else是为了解决extract函数中,for循环中传递的密码长度可能前者的值大于后者,这一bug

if min_len < max_len:

self.min_len = min_len

self.max_len = max_len

else:

self.min_len = max_len

self.max_len = min_len

def iter(self): # 直接返回self实列对象

return self

def next(self): # 通过不断地轮循,生成密码

result_word = ‘’

for i in range(0, random.randint(self.min_len, self.max_len)): # randint取值为[]左右闭区间

result_word += random.choice(MyIter.word) # 从word中随机取选取一个值,并把选取几次的结果拼接成一个字符,即一个密码

return result_word

def extract():

start_time = time.time()

zip_file = zipfile.ZipFile(‘1.zip’, ‘r’)

for password in MyIter(password_min, password_max): # 随机迭代出1~4位数的密码,在不明确位数的时候做相应的调整

if zip_file:

try:

zip_file.extractall(path=‘.’, pwd=str(password).encode(‘utf-8’))

print(“压缩密码为:”, password)

end_time = time.time()

print(‘破解压缩包花了%s秒’ % (end_time - start_time))

sys.exit(0)

except Exception as e:

print(‘pass密码:’, password)

pass

if name == “main”:

password_min = 5 # 设置密码区间长度

password_max = 6 # 设置密码区间长度

os.chdir(r’C:\Users\asuka\Desktop\123’) # 移动到目标所在文件夹

extract()

多线程爆破密码本

========

脚本存在一些缺陷,无法打印出extractfile函数中正确密码

第38行指定工作路径

第39行指定密码本

import zipfile

from threading import Thread

import sys

import os

‘’’

多线程爆破完成

‘’’

def extractfile(zip_file, password):

try:

zip_file.extractall(path=‘.’, pwd=str(password).encode(‘utf-8’))

print(‘[+]’ + zip_file + ’ 解压密码是:', password)

sys.exit(0)

except Exception as e:

print(‘pass错误密码:’, password)

pass

def main(password_file):

files = os.listdir()

for file in files: # 遍历当前路径下的所有文件

if file.endswith(‘.zip’): # 爆破zip文件

zip_file = zipfile.ZipFile(file)

pass_file = open(password_file)

for line in pass_file.readlines():

password = line.strip(‘\n’)

t = Thread(target=extractfile, args=(zip_file, password))

t.start()

if name == ‘main’:

‘’’

脚本默认会对脚本所在文件夹中的zip文件爆破

脚本存在一些缺陷,无法打印出extractfile函数中正确密码

需要手动去终端复制最后一行,那个才是正确密码,用正确密码手动解压文件即可

‘’’

os.chdir(r’C:\Users\asuka\Desktop\123’)

password_file = r’C:\Users\asuka\Desktop\123\password.txt’ # 用来指定密码本的路径

main(password_file)

单线程爆破3合1版(支持数字,数字+字母、密码本)

=========================

第213行,可以指定脚本工作路径

如果删除第213行,脚本会工作在,脚本所在位置

import zipfile

import os

import time

import sys

import random

‘’’

源代码描述:

1:代码中,变量统一使用zip代表压缩包

2:关于空密码

测试发现,当一个压缩包是无密码的时候,给extractall的pwd参数指定密码,依然可以正确提取压缩包

因此无需写代码检查压缩包时候有密码

否则,检查有无密码报异常,有密码爆破再爆异常,搞得代码会很复杂

3:关于zfile.extractall

破解密码用到的zfile.extractall中

extractall要求输入的是字节类型,所以需要手动转

4:关于异常,前面的那段注释

使用try/except时候,pycharm报告Exception太宽泛,我们应该指定异常类型

如果不确定有可能发生的错误类型

在 try 语句前加入 # noinspection PyBroadException 即可让pycharm闭嘴

但是except Exception as e中的e仍然会被pycharm报告说,这个变量没有使用

5:关于解压乱码

我这里是通过修改zipfile的源代码来解决的

修改源代码时,如果无法找到【if zinfo.flag_bits & 0x800】

可能是zipfile版本的问题,请试着搜索【if fheader[_FH_GENERAL_PURPOSE_FLAG_BITS] & 0x800】,或者【fname_str = fname.decode(“utf-8”)】

定位的方式是多样的,不必拘泥

详情参见:

https://secsilm.blog.csdn.net/article/details/79829247

https://wshuo.blog.csdn.net/article/details/80146766?spm=1001.2014.3001.5506

6:关于代码运行位置

由于我的代码往往跟操作的文件不在一个地方,所以在run()函数中使用

#os.chdir(r’') # 此路径是测试的时候使用,用来手动设定压缩包路径

来手动设定脚本工作目录

‘’’

主备前提工作:检查出当前路径中的压缩包,并创建一个同名的文件夹

def ready_work():

files = os.listdir() # 获取脚本工作路径中的所有文件

for file in files: # 遍历脚本工作路径中的所有文件

if file.endswith(‘.zip’): # 找出脚本工作路径中的所有zip文件

开始制造一个新文件夹的路径,用来存放解压结果

a = os.path.splitext(file) # 分离压缩包的名字和后缀

new_path = os.path.join(os.path.abspath(‘.’), str(a[0])) # 把当前脚本运行的路径和压缩包的文件名拼接成新的路径

检查新文件夹的路径是否已存在,如果有就直接使用,如果没有就创建它

if os.path.exists(new_path):

pass

else:

os.makedirs(new_path)

return new_path, file

纯数字爆破

def get_zipfile():

math_max = 1000000 # 设置数字密码的上限

math_min = 1 # 设置数字密码是下限

print(‘默认输入数字下限是1,如需重设请输入,否则请回车键跳过’)

math_min_input = input(‘’)

print(‘默认数字上限是1000000(1百万),如需重设请输入,否则请回车键跳过’)

math_max_input = input(‘’)

if len(math_max_input):

math_max = int(math_max_input)

else:

pass

if len(math_min_input):

math_min = int(math_min_input)

else:

pass

new_path, file = ready_work() # 用来接收ready_work()返回的两个变量

print(‘爆破开始’)

count = 0

开始解压文件

with zipfile.ZipFile(file) as zip_file: # 读取压缩文件

做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。

别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。


(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

(4)200多本电子书

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。

基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。

(5)Python知识点汇总

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。

在这里插入图片描述

(6)其他资料

还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。

在这里插入图片描述

这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 16
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值