服务端代码

import socket

# 1.创建流式套接字实例
# server = socket.socket()
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM, 0) # 2.使用bind方法绑定端口号。服务端绑定的ip和port(参数是元组)
server.bind(("127.0.0.1", 8832)) # 3.调用listen方法监听,并指定最大的连接数量。设置监听套接字,创建监听队列
server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # 设置端口重用
server.listen(5) # 4.等待客户端链接
while True:
print("正在等待客户端链接...")
conn, addr = server.accept()
print("client connent...{0}:{1}".format(addr[0], addr[1]))
# python3.x以上,网络数据的发送接收都是byte类型,如果发送的数据是str类型的则需要进行编码.
conn.send(("连接成功,服务端端口:%s,客户端端口:%s" % (8832, addr[1])).encode()) # 5.收发消息
while True:
data = conn.recv(1024) # 接收客户端发来的消息
# if not data or data.decode("utf-8") == "exit":
if not data or data == b"exit":
break
print(data.decode())
conn.send(("服务端返回信息:%s" % data.decode()).encode()) # 处理客户端数据
conn.close() # 主动关闭连接 # 6.关闭套接字
server.close()

知识点1:设置端口重用:server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)。

知识点2:conn, addr = server.accept()的返回值是一个元组:返回的conn代表一个新的套接字用来和客户端通信。返回的addr是连接的客户端的地址(也是元组,包含ip与端口)。

知识点3:发送send()函数,与接收recv()函数,操作的都是字节串。recv()函数是阻塞函数。

客户端代码

import socket

# 1.socket实例初始化
# client = socket.socket()
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 2.发起连接:根据服务端绑定的ip和端口,进行连接访问服务端
client.connect(("127.0.0.1", 8832)) # 3.与服务端交互,接收发送信息
while True:
data = client.recv(1024) # 接收主机信息
print(data.decode()) # 打印接收的数据,此处的byte类型数据特指python3.x以上
msg = input("请输入要发送的信息...")
client.send(msg.encode())
if not msg or msg == "exit":
break # 4.关闭套接字
client.close()

1.服务端与客户端可以一直通信,收发消息。直到客户端输入"exit",客户端退出,服务端等待下一个客户端连接。

2.当第一个客户端与服务端一直连着的时候,第二个客户端无法与服务器连接。直到第一个客户端退出与服务器的连接,第二个客户端才能与服务器连接。

3.当第一个客户端退出时,服务器会立马连接第二个客户端。第二个客户端之前发的信息,服务器就会收到,并返回信息。可能第二个发送端发的信息都在发送缓冲区里。

封装服务端代码

import socket, threading

class Server():
# 创建socket
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM, 0)
# 绑定端口号
server.bind(("127.0.0.1", 3120))
# 调用listen()方法监听端口,并限制最大数量连接
server.listen(5) def tcpLink(self, sock, addr):
print('Connection from %s:%s' % addr)
sock.send(b'Welcome...')
while True:
data = sock.recv(1024)
if not data or data.decode("utf-8") == "exit":
break
print(data.decode())
sock.send(('Received data:{0}'.format(data.decode())).encode())
sock.close() def tcpServer(self):
while True:
sock, addr = self.server.accept() # 接受一个连接
t = threading.Thread(target=self.tcpLink, args=(sock, addr))
t.start() if __name__ == "__main__":
tcpserver = Server()
tcpserver.tcpServer()

封装客户端代码

import socket

class Client():
# 建立一个连接,指定TCP方式
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM, 0)
# 连接服务端的3120端口
client.connect(("127.0.0.1", 3120))
print(client.recv(1024).decode('utf-8')) def tcpClient(self):
while True:
msg = input("请输入要发送的信息...")
self.client.send(msg.encode())
if not msg or msg == "exit":
break
data = self.client.recv(1024)
print(data.decode()) if __name__ == "__main__":
tcpclient = Client()
tcpclient.tcpClient()

参考:https://www.liaoxuefeng.com/wiki/1016959663602400/1017788916649408

Python—网络通信编程之tcp通信编程的更多相关文章

  1. Python—网络通信编程之udp通信编程

    服务端代码 import socket # 1.创建实例,即数据报套接字 server = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 2.绑 ...

  2. Python—网络通信编程之tcp非阻塞通信(socketserver)

    服务端代码 import socketserver # 定义一个类 class MyServer(socketserver.BaseRequestHandler): # 如果handle方法出现报错, ...

  3. python网络编程之TCP通信实例

    一. server.py import socket host="localhost" port= s=socket.socket(socket.AF_INET,socket.SO ...

  4. Python网络编程之TCP套接字简单用法示例

    Python网络编程之TCP套接字简单用法示例 本文实例讲述了Python网络编程之TCP套接字简单用法.分享给大家供大家参考,具体如下: 上学期学的计算机网络,因为之前还未学习python,而jav ...

  5. java 网络编程之TCP通信和简单的文件上传功能

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

  6. Java网络编程之TCP通信

    一.概述 Socket类是Java执行客户端TCP操作的基础类,这个类本身使用代码通过主机操作系统的本地TCP栈进行通信.Socket类的方法会建立和销毁连接,设置各种Socket选项. Server ...

  7. [Python] 网络编程之TCP编程

    转自:TCP编程 - 廖雪峰的官方网站 Socket是网络编程的一个抽象概念.通常我们用一个Socket表示“打开了一个网络链接”,而打开一个Socket需要知道目标计算机的IP地址和端口号,再指定协 ...

  8. python 网络编程之TCP传输&粘包传输

    只有TCP有粘包现象,UDP永远不会粘包. 所谓粘包问题主要还是C/S两端数据传输时 因为接收方不知道消息之间的界限,不知道一次性提取多少字节的数据所造成的 根本原因:粘包是由TCP协议本身造成的,T ...

  9. 网络编程之TCP编程

    网络编程之TCP编程 前面已经介绍过关于TCP协议的东西,这里不做赘述.Java对于基于TCP协议的网络通信提供了良好的封装,Java使用socket对象来代表两端的通信窗口,并通过Socket产生I ...

随机推荐

  1. [].slice.call(k).filter(function(l) { return l != 0 });

    [].slice.call(k).filter(function(l) { return l != 0 }); 将类数组调用数组方法.

  2. excel表格 函数功能

    1.去重复 选中一个区域——>数据——>删除重复项 2.条件求和 按照条件筛选:筛选出一样的类目,将对应的值求和. =sumif(A$1:A$10,B2,C$1:C$10) A$1:A$1 ...

  3. 测量设备自动化-AK协议

    1.AK协议定义 AK协议是控制器和测量设备之间通信的方式,广泛应用于整车耐久转毂等测试中,如AVL VECON.人们通常都是用VECON界面设置试验曲线,但通过AK可以实现设备的自动化.如下图所示: ...

  4. python实现队列(queue)

    队列队列是一种先进先出的数据结构,主要操作包括入队,出队.入队的元素加入到对尾,从队头取出出队的元素.这里用列表简单模拟队列,其实现如下: queue()is_empty()size()enqueue ...

  5. ScrollView不设置contentSize属性依然也可以作为底层滚动View(使用masonry设置scrollView的contentSize)

    第一步 //下层的scroolView self.baseScrollView = [[UIScrollView alloc] init]; self.baseScrollView.delegate ...

  6. vue学习笔记:vue的认识与特点与获取

    Vue了解 Vue:读作 view Vue是一个渐进式框架 与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计. Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整 ...

  7. nginx 加工上游服务器返回的内容,并返回给客户端

    禁用上游响应头部功能 Syntax: proxy_ignore_headers field ...; Default: — Context: http, server, location 功能介绍:某 ...

  8. Linux命令:route命令

    route显示或修改IP路由表 route -n:显示路由信息,使用数字格式显示,不反解地址到主机名 #route -n Kernel IP routing table Destination Gat ...

  9. node.js中的事件轮询Event Loop

    任务队列/事件队列 "任务队列"是一个事件的队列,IO设备完成一项任务,就在"任务队列"中添加一个事件,表示相关的异步任务可以进入"执行栈" ...

  10. error C2664: “FILE *fopen(const char *,const char *)”: 无法将参数 1 从“LPCTSTR”转换为“const char *”

    遇到这个问题,请打开本项目的Properties(属性)-------> Configuration Properties(配置属性)-------->General(常规)------- ...