socket网络编程解决TCP客户端和服务端问题——python
问题描述
A和B采用TCP通信,连接成功以后,A的起始序列号是500,B的起始序列号是800,A首先发起通信,发出消息:Hello!(6个字节);此消息B正确收到,B回复ACK,请问此时的ACK Num是多少? A收到ACK回复后,再次发送消息:Are you OK? (11个字节),此消息丢失,此时,B发出消息给A:Hello!(6个字节),请问此时B发出的消息中的ACK Num是多少? 此消息A正确收到,A将如何做?如果A发消息,消息中的sequence Number和Ack Number分别是多少?
设计一个实验来进行实地测试,给出测试结果截图。
请使用手写拍照方式回答,且需要画图说明A和B的通信过程,并给出各个问题的答案。注意一定要按照思源学堂提交图片作业的要求提交,否则无效不能得分。
实验准备与环境
应用软件:spyder、clumsy
语言:python(需要socket、eventlet、time库)
实验步骤
1.根据题意用python的socket库编写客户端client和服务器server的代码。
client.py
# -*- coding: utf-8 -*-
"""
Created on Wed Mar 30 00:10:09 2022
@author: YUZI
"""
import socket
import time
import eventlet
eventlet.monkey_patch()
#创建一个客户端的socket对象
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#设置服务端的ip地址
host = "127.0.0.1"
#设置端口
port = 9092
#连接服务端
client.connect((host, port))
#while循环是为了保证能持续进行对话
while True:
#输入发送的消息
sendmsg = input("请输入:")
#如果客户端输入的是q,则停止对话并且退出程序
if sendmsg=='q':
break
sendmsg = sendmsg
#发送数据,以二进制的形式发送数据,所以需要进行编码
client.send(sendmsg.encode("utf-8"))
with eventlet.Timeout(10,False):
msg = client.recv(1024)
#接收服务端返回的数据,需要解码
print(msg.decode("utf-8"))
time.sleep(1)
#关闭客户端
client.close()
server.py
# -*- coding: utf-8 -*-
"""
Created on Wed Mar 30 00:12:02 2022
@author: YUZI
"""
import socket
import time
import eventlet
eventlet.monkey_patch()
#创建服务端的socket对象socketserver
socketserver = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
host = '0.0.0.0'
port = 9092
#绑定地址(包括ip地址会端口号)
socketserver.bind((host, port))
#设置监听
socketserver.listen(5)
#等待客户端的连接
#注意:accept()函数会返回一个元组
#元素1为客户端的socket对象,元素2为客户端的地址(ip地址,端口号)
clientsocket,addr = socketserver.accept()
#while循环是为了能让对话一直进行,直到客户端输入q
while True:
#接收客户端的请求
with eventlet.Timeout(10,False):
recvmsg = clientsocket.recv(1024)
#把接收到的数据进行解码
strData = recvmsg.decode("utf-8")
#判断客户端是否发送q,是就退出此次对话
if strData=='q':
break
print("收到:"+strData)
time.sleep(0.01)
with eventlet.Timeout(10,False):
msg = input("回复:")
#对要发送的数据进行编码
clientsocket.send(msg.encode("utf-8"))
time.sleep(0.01)
socketserver.close()
2.接下来对clumsy进行设置,使其能够将“are you ok?”精准丢包:
过滤条件:tcp and outbound and ip.DstAddr == 127.0.0.1 and tcp.PayloadLength == 11 and tcp.DstPort == 9092
3.新开一个console控制台,打开wireshark进行抓包,然后分别运行server.py
,client.py
,如图所示。
4.观察wireshark抓包数据,如图所示