gpt4 book ai didi

python - 尝试多进程时如何修复 "TypeError: cannot serialize ' _io.BufferedReader' object"错误

转载 作者:可可西里 更新时间:2023-11-01 10:02:29 25 4
gpt4 key购买 nike

我正在尝试将代码中的线程切换为多处理以衡量其性能,并希望实现更好的暴力破解潜力,因为我的程序旨在暴力破解受密码保护的 .zip 文件。但是每当我尝试运行该程序时,我都会得到:

BruteZIP2.py -z "Generic ZIP.zip" -f  Worm.txt
Traceback (most recent call last):
File "C:\Users\User\Documents\Jetbrains\PyCharm\BruteZIP\BruteZIP2.py", line 40, in <module>
main(args.zip, args.file)
File "C:\Users\User\Documents\Jetbrains\PyCharm\BruteZIP\BruteZIP2.py", line 34, in main
p.start()
File "C:\Users\User\AppData\Local\Programs\Python\Python37\lib\multiprocessing\process.py", line 112, in start
self._popen = self._Popen(self)
File "C:\Users\User\AppData\Local\Programs\Python\Python37\lib\multiprocessing\context.py", line 223, in _Popen
return _default_context.get_context().Process._Popen(process_obj)
File "C:\Users\User\AppData\Local\Programs\Python\Python37\lib\multiprocessing\context.py", line 322, in _Popen
return Popen(process_obj)
File "C:\Users\User\AppData\Local\Programs\Python\Python37\lib\multiprocessing\popen_spawn_win32.py", line 65, in __init__
reduction.dump(process_obj, to_child)
File "C:\Users\User\AppData\Local\Programs\Python\Python37\lib\multiprocessing\reduction.py", line 60, in dump
ForkingPickler(file, protocol).dump(obj)
TypeError: cannot serialize '_io.BufferedReader' object

我确实找到了与我有相同问题的线程,但它们都没有得到答复/未解决。我还尝试在 p.start() 上方插入 Pool,因为我认为这是由于我使用的是基于 Windows 的机器,但没有帮助。我的代码如下:

  import argparse
from multiprocessing import Process
import zipfile

parser = argparse.ArgumentParser(description="Unzips a password protected .zip by performing a brute-force attack using either a word list, password list or a dictionary.", usage="BruteZIP.py -z zip.zip -f file.txt")
# Creates -z arg
parser.add_argument("-z", "--zip", metavar="", required=True, help="Location and the name of the .zip file.")
# Creates -f arg
parser.add_argument("-f", "--file", metavar="", required=True, help="Location and the name of the word list/password list/dictionary.")
args = parser.parse_args()


def extract_zip(zip_file, password):
try:
zip_file.extractall(pwd=password)
print(f"[+] Password for the .zip: {password.decode('utf-8')} \n")
except:
# If a password fails, it moves to the next password without notifying the user. If all passwords fail, it will print nothing in the command prompt.
print(f"Incorrect password: {password.decode('utf-8')}")
# pass


def main(zip, file):
if (zip == None) | (file == None):
# If the args are not used, it displays how to use them to the user.
print(parser.usage)
exit(0)
zip_file = zipfile.ZipFile(zip)
# Opens the word list/password list/dictionary in "read binary" mode.
txt_file = open(file, "rb")
for line in txt_file:
password = line.strip()
p = Process(target=extract_zip, args=(zip_file, password))
p.start()
p.join()


if __name__ == '__main__':
# BruteZIP.py -z zip.zip -f file.txt.
main(args.zip, args.file)

正如我之前所说,我认为这主要是因为我现在使用的是基于 Windows 的计算机。我与其他一些使用基于 Linux 的机器的人分享了我的代码,他们运行上面的代码没有问题。

我的主要目标是启动 8 个进程/池,以最大化与线程相比完成的尝试次数,但由于我无法修复 TypeError: cannot serialize '_io.BufferedReader' object 消息 我不确定在这里做什么以及如何继续修复它。如有任何帮助,我们将不胜感激。

最佳答案

文件句柄不能很好地序列化...但是您可以发送 zip 文件的 name 而不是 zip filehandle(进程之间的字符串序列化没问题).并避免为您的文件名使用 zip,因为它是内置的。我选择了 zip_filename

p = Process(target=extract_zip, args=(zip_filename, password))

然后:

def extract_zip(zip_filename, password):
try:
zip_file = zipfile.ZipFile(zip_filename)
zip_file.extractall(pwd=password)

另一个问题是您的代码不会因此而并行运行:

      p.start()
p.join()

p.join 等待进程完成...几乎没用。您必须存储进程标识符以在最后加入它们。

这可能会导致其他问题:并行创建太多进程可能会对您的机器造成问题,并且在某些时候不会有太大帮助。考虑一个 multiprocessing.Pool相反,限制 worker 的数量。

简单的例子是:

with multiprocessing.Pool(5) as p:
print(p.map(f, [1, 2, 3, 4, 5, 6, 7]))

适应你的例子:

with multiprocessing.Pool(5) as p:
p.starmap(extract_zip, [(zip_filename,line.strip()) for line in txt_file])

(starmap 将元组扩展为 2 个单独的参数以适合您的 extract_zip 方法,如 Python multiprocessing pool.map for multiple arguments 中所述)

关于python - 尝试多进程时如何修复 "TypeError: cannot serialize ' _io.BufferedReader' object"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54507527/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com