为什么此客户端-服务器系统不起作用(简单)

问题描述 投票:0回答:2

我正在尝试使一个非常简单的客户端系统变得简单,但我不确定它有什么问题。它应该是一个计算器系统。这是客户端的代码:

import socket

IP = '127.0.0.1'
PORT = 8106

my_socket = socket.socket()
my_socket.connect((IP, PORT))


done = False

while not done:
    command = raw_input("choose a command from [ADD, SUB, MUL, DIV, EXIT]")
    command = command.upper()
    my_socket.send(command)
    data = my_socket.recv(20)
    new_list = data.split(":")
    if command in ["ADD", "SUB", "MUL", "DIV", "EXIT"]:
        if command == "ADD":
            print new_list[0] + "+" + new_list[1] + "=" + new_list[2]
        if command == "SUB":
            print new_list[0] + "-" + new_list[1] + "=" + new_list[2]
        if command == "MUL":
            print new_list[0] + "*" + new_list[1] + "=" + new_list[2]
        if command == "DIV":
            print new_list[0] + "/" + new_list[1] + "=" + new_list[2]
        if command == "EXIT":
            done = True
    else:
        print 'not valid'






这是服务器的代码:

import socket
import random

IP = '0.0.0.0'
PORT = 8106

server_socket = socket.socket()
server_socket.bind((IP, PORT))

server_socket.listen(1)

(client_socket, client_address) = server_socket.accept()


done = False

while not done:
    message = client_socket.recv(4)
    num1 = random.randint(-101, 100)
    print num1
    num2 = random.randint(-101, 100)
    print num2
    if message in ["ADD", "SUB", "MUL", "DIV", "EXIT"]:
        if message == "ADD":
            result = num1 + num2
        elif message == "SUB":
            result = num1 - num2
        elif message == "MUL":
            result = num1 * num2
        elif message == "DIV":
            result = float(num1) / float(num2)
        elif message == "EXIT":
            done = True
        client_socket.send(str(num1) + ":" + str(num2) + ":" + str(result))
    else:
        client_socket.send("0:0:0")

现在,当我先运行服务器再运行客户端,并选择两次“ DIV”时,第一次也可以,但是在第二次或第三次尝试时,我收到一条错误消息:

print new_list[0] + "/" + new_list[1] + "=" + new_list[2]
IndexError: list index out of range

我不确定为什么会这样。我尝试打印“数据”以尝试解决它,有时数据只是一个数字,例如46,而不是类似46:3:15.333

为什么会这样?

python python-2.7 server client client-server
2个回答
0
投票

socket.send不能保证完整数据的打磨。您的应用程序应根据socket.send返回值检查发送了多少字节。

或者仅使用socket.sendall并检查类似的异常:

try:
    s.sendall(MESSAGE)
except socket.error:
    # failed to send

请参见socket.send中的socket.sendalldocs


0
投票

socket.recv(bufsize[, flags])方法的文档指定以下内容:

一次接收的最大数据量由bufsize指定。

关键部分是bufsize是您从单个调用中接收到的最大字节数,因此,您接收到的单个字节字符串在数量和大小上可能并不完全相同。您在另一侧致电send

对于使用默认类型(SOCK_STREAM即TCP)创建的套接字,唯一保证的是字节流的发送顺序与发送顺序相同。因此,您必须设计一个协议,该协议允许客户端和服务器都标识每个单独消息的边界。

这里有几种方法可以实现:

    在邮件本身中包含有关每个邮件长度的信息。例如,每个消息的第一个字节可以是一个整数,该整数给出了其余消息的长度,给出的最大消息大小为255(不包括长度前缀)。
  1. 使每封邮件的大小相同。这样,您就不必在消息中对长度进行编码-您可以继续调用recv,直到获得所需的字节数为止。不过,您必须确保可以使用相同的格式和长度来表示每个数字。
  2. 编辑:根据kirill's answer,您还必须修复用于发送数据的代码(例如,使用sendall)。但是,如果没有进一步的信息,就不可能说出这些问题中的哪个是导致您的问题的原因。
© www.soinside.com 2019 - 2024. All rights reserved.