网络服务器和客户端的编写

"""1、创建TCP服务器"""
import socket # 用于网络通信

import threading # 创建多线程处理客户端请求
import time # 用于添加数据时用于延迟,模拟网路传输

# 建立TCP连接

s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

# 绑定地址及监听端口

s.bind(('127.0.0.1',6666)) # 将服务器IP地址和端口号绑定到socket对象上,这里使用'127.0.0.1'是本地主机地址,即IP地址的最后一个部分为'1'

# 调用listen方法监听端口,参数5表示最大连接数,即"队列"大小

s.listen(5)

# 打印等待连接的信息

print('Wait for connection...')

# 服务器端应答函数

def tep(sock,addr):
print('Accept new connection from %s:%s...'% addr)

向客户端发送应答消息"Success!"(这里应答消息是硬编码的,实际应用中可能需要根据实际情况发送不同的应答)

sock.send(b'Success!')

进入一个无限循环,处理来自客户端的消息

while True:

从客户端接收最多1024字节的消息

data = sock.recv(1024)

接收数据后,延迟1秒 (实际时间取决于操作系统的时间粒度)

time.sleep(1)

# 如果没有接收到数据,或者接收到的数据解码后为"exit",则跳出循环

if not data or data.decode('utf-8') == 'exit':
break

向客户端发送消息"Welcom! {数据内容}!"并编码为utf-8格式(实际应用中可能需要根据实际情况发送不同的消息)

sock.send(('Welcom! %s!' % data.decode('utf-8')).encode('utf-8'))

关闭与客户端的连接

sock.close()

打印连接关闭的信息

print('Connection from %s:%s closed.' % addr)

# 循环处理客户端连接

while True:

接受来自客户端的新连接:

sock,addr = s.accept()

创建新线程来处理TCP连接

t = threading.Thread(target=tep,args=(sock,addr))
t.start()

""" 2、实现客户端"""
# 导入socket库

import socket

建立TCP连接

s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

与服务器建立连接

print(s.connect('127.0.0.1',6666))

接受服务器的连接成功提示信息

print(s.recv(1024).decode('utf-8'))

发送数据并接受服务器返回结果

for data in [b'Tom',b'Jerry',b'Spike']:
s.send(data)
print(s.recv(1024).decode('utf-8'))

发送退出信息断开连接

s.send(b'exit')
s.close()

Wait for connection...

相关推荐
如若1231 小时前
AutoDL云服务器 NVIDIA 570驱动 EGL渲染修复全记录
运维·服务器·python
i建模1 小时前
Omarchy设置防火墙
linux·运维
甲枫叶1 小时前
【claude】Claude Code正式引入Git Worktree原生支持:Agent全面实现并行独立工作
java·人工智能·git·python·ai编程
德迅云安全-小潘1 小时前
德迅零域(微隔离):破解云时代横向渗透困局的“手术刀”
网络·数据库·安全
晚秋大魔王1 小时前
泰拉瑞亚手机版服务器部署
运维·服务器·泰拉瑞亚
敲代码的哈吉蜂1 小时前
高可用集群Keepalived
运维·服务器·网络·数据库
S-码农2 小时前
Linux ——条件变量
linux·开发语言
爱写代码的liding2 小时前
linux安装软件过程中报找不到某些动态链接.so文件
linux
清水白石0082 小时前
《Python 编程全景解析:从核心精要到 Hypothesis 属性基测试的边界探索》
开发语言·python
青衫码上行2 小时前
【项目部署】Spring Boot项目部署的四种方式
java·linux·服务器·spring boot·后端·docker·腾讯云