Тайм-аут Winpexpect из-за отсутствия данных от spawn - PullRequest
0 голосов
/ 14 марта 2020

Я пытаюсь автоматизировать ввод в "игру" для своего класса вредоносных программ, для решения которой требуется динамический анализ c. Чтобы уточнить, я уже решил игру, сейчас я просто пытаюсь автоматизировать процесс с помощью python вместо того, чтобы вручную проходить код с помощью отладчика Ida.

Я использую winpexpect что рекомендуется для Windows пользователей (файл является 32-битным windows исполняемым файлом) в документации для pexpect . Он ожидает истечения времени ожидания для вывода подпроцесса, но никогда ничего не получает. Соответствующий код, который я использую:

from winpexpect import winspawn as spawn
from sys import stdout
from time import time
from numpy import uint32

child = spawn('TheGame_3.exe')
child.logfile_read = stdout

child.expect('Enter your name: ')
child.sendline('')
child.expect('Enter your choice: ')
child.sendline('3')

et c. Я попытался написать простой скрипт для запуска, и этот код, кажется, отлично работает на этом:

print(input('Enter your name: '))
print(input('Enter your choice: '))

Но когда я запускаю его на реальном exe, я получаю эту ошибку (Mr-Windy - пользователь моего Windows VM):

Traceback (most recent call last):
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\site-packages\winpexpect.py", line 541, in read_nonblocking
    handle, status, data = self.child_output.get(timeout=timeout)
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\queue.py", line 178, in get
    raise Empty
_queue.Empty

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\site-packages\pexpect.py", line 1378, in expect_loop
    c = self.read_nonblocking (self.maxread, timeout)
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\site-packages\winpexpect.py", line 543, in read_nonblocking
    raise TIMEOUT('Timeout exceeded in read_nonblocking().')
pexpect.TIMEOUT: Timeout exceeded in read_nonblocking().

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\Mr-Windy\Documents\NPS\Lab6\DirectedInput.py", line 12, in <module>
    child.expect('Enter your name: ')
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\site-packages\pexpect.py", line 1311, in expect
    return self.expect_list(compiled_pattern_list, timeout, searchwindowsize)
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\site-packages\pexpect.py", line 1325, in expect_list
    return self.expect_loop(searcher_re(pattern_list), timeout, searchwindowsize)
  File "C:\Users\Mr-Windy\AppData\Local\Programs\Python\Python37\lib\site-packages\pexpect.py", line 1409, in expect_loop
    raise TIMEOUT (str(e) + '\n' + str(self))
pexpect.TIMEOUT: Timeout exceeded in read_nonblocking().
<winpexpect.winspawn object at 0x000002869CFC5C88>
version: 2.3 ($Revision: 399 $)
command: TheGame_3.exe
args: ['TheGame_3.exe']
searcher: searcher_re:
    0: re.compile("Enter your name: ")
buffer (last 100 chars): 
before (last 100 chars): 
after: <class 'pexpect.TIMEOUT'>
match: None
match_index: None
exitstatus: None
flag_eof: False
pid: 7696
child_fd: 3
closed: False
timeout: 30
delimiter: <class 'pexpect.EOF'>
logfile: None
logfile_read: <_io.TextIOWrapper name='<stdout>' mode='w' encoding='utf-8'>
logfile_send: None
maxread: 2000
ignorecase: False
searchwindowsize: None
delaybeforesend: 0.05
delayafterclose: 0.1
delayafterterminate: 0.1

... что, по-видимому, указывает на то, что ничего не записывается в стандартный вывод. Исполняемый файл печатает на стандартный вывод и принимает данные через стандартный ввод при обычном выполнении, поэтому я действительно озадачен тем, что делаю неправильно.

Любая помощь приветствуется. Заранее спасибо.

...