Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/sockets/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 3.x 使用套接字发送多个图像_Python 3.x_Sockets_Tcp_Python Sockets - Fatal编程技术网

Python 3.x 使用套接字发送多个图像

Python 3.x 使用套接字发送多个图像,python-3.x,sockets,tcp,python-sockets,Python 3.x,Sockets,Tcp,Python Sockets,在用Python制作VNC的一次雄心勃勃的尝试中,我试图不断地将一个用户(服务器)的屏幕截图发送给另一个用户(客户端)。经过几个小时的努力,达到了鲍尔默的巅峰,我终于做到了。然而,现在我的问题是发送多个图像,一个连续的图像流。我首先尝试将所有二进制数据写入一个文件,但没有成功。当第二个图像被打开时,它崩溃了。我想这可能是因为二进制数据被破坏了,所以我试着为每个图像创建一个新文件,但我也遇到了同样的问题。我知道Tcp是一个恒定的数据流,因此很难知道第一个图像的结束和下一个图像的开始,但是通过创建另

在用Python制作VNC的一次雄心勃勃的尝试中,我试图不断地将一个用户(服务器)的屏幕截图发送给另一个用户(客户端)。经过几个小时的努力,达到了鲍尔默的巅峰,我终于做到了。然而,现在我的问题是发送多个图像,一个连续的图像流。我首先尝试将所有二进制数据写入一个文件,但没有成功。当第二个图像被打开时,它崩溃了。我想这可能是因为二进制数据被破坏了,所以我试着为每个图像创建一个新文件,但我也遇到了同样的问题。我知道Tcp是一个恒定的数据流,因此很难知道第一个图像的结束和下一个图像的开始,但是通过创建另一个文件,我认为我会很好

非常感谢您在解决此问题和/或提高效率方面提供的任何帮助:)

服务器端:

import socket
from PIL import Image, ImageGrab

PORT = 10007
HOST = '127.0.0.1'

with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
    s.bind((HOST, PORT))
    s.listen()
    conn, addr = s.accept()
    with conn:

        counter = 3

        while counter > 0:
            image = ImageGrab.grab(bbox=None)
            image.save('test.png')

            f = open('test.png', 'rb')

            l = f.read(1024)

            while (l):
                conn.send(l)
                l = f.read(1024)

            f.close()
            print('Done sending curr image')
            counter -= 1

conn.close()
客户端:

import socket
from PIL import Image

HOST = '127.0.0.1'
PORT = 10007


with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
    s.connect((HOST, PORT))


    counter = 1

    while counter != 3:
        fname = 'image' + str(counter) + '.png'

        with open(fname, 'wb') as file:

            print('file opened')

            while True:
                data = s.recv(1024)
                if not data:
                    break
                else:
                    file.write(data)

        file.close()
        currImg = Image.open(fname)
        currImg.show()
        counter += 1






s.close()

您的接收者不知道一个文件何时完成,下一个文件何时开始。最简单的修复方法是在发送每个文件之前将文件的长度(可能是4字节无符号值)发送给接收方。然后接收器可以读取长度,读取文件,读取长度,读取文件

为了提高效率,您可以停止将文件数据保存到两端的实际文件中,而是将其保存到内存缓冲区中(显然,可以从中读取)。有关如何执行此操作的说明,请参见。在Python3中,看起来您将使用
BytesIO
模块

另一个改进是只发送自上次发送以来已更改的屏幕部分的图像数据。为此,您需要弄清楚如何将当前捕获与前一个捕获进行比较。对于第一个过程,您可以使用
PIL.ImageChops.difference
,然后使用
PIL.Image.getbbox
,然后只编码并发送当前捕获的区域。为了实现这一点,发送者不仅要告诉接收者PNG的大小,还要告诉接收者在输出屏幕图像中应该在哪里绘制新的图像补丁。因此,除了大小和编码的图像数据之外,您还需要发送一个位置