Python—网络通信编程之tcp通信编程
服务端代码
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通信编程的更多相关文章
- Python—网络通信编程之udp通信编程
服务端代码 import socket # 1.创建实例,即数据报套接字 server = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 2.绑 ...
- Python—网络通信编程之tcp非阻塞通信(socketserver)
服务端代码 import socketserver # 定义一个类 class MyServer(socketserver.BaseRequestHandler): # 如果handle方法出现报错, ...
- python网络编程之TCP通信实例
一. server.py import socket host="localhost" port= s=socket.socket(socket.AF_INET,socket.SO ...
- Python网络编程之TCP套接字简单用法示例
Python网络编程之TCP套接字简单用法示例 本文实例讲述了Python网络编程之TCP套接字简单用法.分享给大家供大家参考,具体如下: 上学期学的计算机网络,因为之前还未学习python,而jav ...
- java 网络编程之TCP通信和简单的文件上传功能
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- Java网络编程之TCP通信
一.概述 Socket类是Java执行客户端TCP操作的基础类,这个类本身使用代码通过主机操作系统的本地TCP栈进行通信.Socket类的方法会建立和销毁连接,设置各种Socket选项. Server ...
- [Python] 网络编程之TCP编程
转自:TCP编程 - 廖雪峰的官方网站 Socket是网络编程的一个抽象概念.通常我们用一个Socket表示“打开了一个网络链接”,而打开一个Socket需要知道目标计算机的IP地址和端口号,再指定协 ...
- python 网络编程之TCP传输&粘包传输
只有TCP有粘包现象,UDP永远不会粘包. 所谓粘包问题主要还是C/S两端数据传输时 因为接收方不知道消息之间的界限,不知道一次性提取多少字节的数据所造成的 根本原因:粘包是由TCP协议本身造成的,T ...
- 网络编程之TCP编程
网络编程之TCP编程 前面已经介绍过关于TCP协议的东西,这里不做赘述.Java对于基于TCP协议的网络通信提供了良好的封装,Java使用socket对象来代表两端的通信窗口,并通过Socket产生I ...
随机推荐
- SpringBoot与Mybatis整合(包含generate自动生成代码工具,数据库表一对一,一对多,关联关系中间表的查询)
链接:https://blog.csdn.net/YonJarLuo/article/details/81187239 自动生成工具只是生成很单纯的表,复杂的一对多,多对多的情况则是在建表的时候就建立 ...
- pta谁先倒
传送门 #include <stdio.h> int main() { int x,y;//酒量 scanf("%d%d",&x,&y); int n; ...
- kafka connector
Kafka Connect 是一种用于在 Kafka 和其他系统之间可扩展的.可靠的的流式传输数据的工具.它使得能偶快速定义将大量数据集合移入和移除 kafka 连接器变得简单. kafka conn ...
- 【原】rsync使用
在使用jenkins当跳板机的场景下,有使用git pull 代码到jenkins机器后,需要将代码复制到另一台机器上,常用的复制命令有scp和rsync:现就使用到了rsync进行详解: rsync ...
- C++11特性中的stoi、stod
本文摘录柳神笔记: 使⽤ stoi . stod 可以将字符串 string 转化为对应的 int 型. double 型变量,这在字符串处理的很 多问题中很有帮助-以下是示例代码和⾮法输⼊的处理 ...
- java中关于&0xFF 的问题
最近遇到一个问题,半天也没想明白,byte temp = 0xA0,为什么System.out.println(temp),打印的值为:-96:而System.out.println(temp& ...
- AF(操作者框架)系列(1)-LabVIEW中的模块化应用概述
一.引子 在前面对LabVIEW介绍的文章中,关于框架开发的内容涉及很少.为了讲解操作者框架(Actor Framework)的优缺点,也只是拿出来QDSM(Queue-Driven State Ma ...
- Ajax案例
展示页面jsp: <%@ page language="java" contentType="text/html; charset=utf-8" pa ...
- springboot中关于datasource的配置
datasource spring.dao.exceptiontranslation.enabled: 是否开启PersistenceExceptionTranslationPostProcessor ...
- gitlab的搭建与使用(一)
yum install curl policycoreutils openssh-server openssh-clients postfix -y systemctl enable sshd sys ...