python高级04——网络编程

1、ip和端口介绍

1-1、网络介绍

1-2、IP地址的介绍

1-3、ifconfig和ping命令

1-4、端口和端口号介绍

端口是传输数据的通道,区分端口用端口号。

1-5、端口号的分类

知名端口号

动态端口号

2、TCP介绍

2-1、socket介绍

2-2、TCP介绍

TCP特点如下:

2-3、python3编码转换

3、TCP开发流程

3-1、TCP客户端开发

客户端:主动发起连接请求。

客户端开发流程:

客户端开发:

python 复制代码
import socket #导入模块

if __name__ == '__main__':
    tcp_client_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #创建客户端套接字对象
    tcp_client_socket.connect(("192.168.8.154",8888)) #连接服务器
    tcp_client_socket.send("hello world".encode(encoding="utf-8")) #发送数据
    recv_data=tcp_client_socket.recv(1024) #接收数据
    print(recv_data.decode(encoding="utf-8"))
    tcp_client_socket.close() #关闭连接

3-2、TCP服务端开发

开发流程:

开发:

python 复制代码
import socket

tcp_server_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #创建sockte对象
tcp_server_socket.bind(("",8888)) #绑定IP和端口号
#tcp_server_socket.bind(("192.168.8.154",8888)) 也可以什么都不写
tcp_server_socket.listen(128) #设置监听,128代表服务端等待连接的最大请求,只能处理连接请求,不能接收数据
conn_socket,ip_port=tcp_server_socket.accept() #接受连接,阻塞等待,返回一个和客户端通信的socket和客户端地址
recv_data=conn_socket.recv(1024) #接收数据
print("接收的数据是:",recv_data.decode(encoding="utf8"))
conn_socket.send("已接收到数据".encode(encoding="utf8"))
conn_socket.close() #关闭连接
tcp_server_socket.close()

端口复用

python 复制代码
import socket

tcp_server_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
tcp_server_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,True) #设置端口复用
tcp_server_socket.bind(("",8888))
tcp_server_socket.listen(128)
conn_socket,ip_port=tcp_server_socket.accept() 
recv_data=conn_socket.recv(1024) 
print("接收的数据是:",recv_data.decode(encoding="utf8"))
conn_socket.send("已接收到数据".encode(encoding="utf8"))
conn_socket.close() 
tcp_server_socket.close()

3-3、socket中send和recv原理

TCP socket的发送和接收缓冲区

缓冲区:现存储数据,达到一定数量直接发出。

send原理

recv原理

4、多任务案例

TCP服务器端

下面的程序可以服务多个客户端,但不能同时服务。

python 复制代码
import socket

tcp_server_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
tcp_server_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,True) #设置端口复用
tcp_server_socket.bind(("",8888))
tcp_server_socket.listen(128)
while True:
    conn_socket, ip_port = tcp_server_socket.accept()
    recv_data = conn_socket.recv(1024)
    print("接收的数据是:", recv_data.decode(encoding="utf8"))
    conn_socket.send("已接收到数据".encode(encoding="utf8"))
    conn_socket.close()
tcp_server_socket.close()

TCP多任务服务器

使用多任务可以实现一个服务器同时服务多个客户,本例用线程。

python 复制代码
import socket
import threading

def handle_client(conn_socket):
    recv_data = conn_socket.recv(1024)
    print("接收的数据是:", recv_data.decode(encoding="utf8"))
    conn_socket.send("已接收到数据".encode(encoding="utf8"))
    conn_socket.close()

tcp_server_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
tcp_server_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,True) #设置端口复用
tcp_server_socket.bind(("",8888))
tcp_server_socket.listen(128)
while True:
    conn_socket, ip_port = tcp_server_socket.accept()
    sub_thread=threading.Thread(target=handle_client,args=(conn_socket,))
    sub_thread.start()
tcp_server_socket.close()
相关推荐
Dream of maid33 分钟前
Python12(网络编程)
开发语言·网络·php
菜菜艾1 小时前
基于llama.cpp部署私有大模型
linux·运维·服务器·人工智能·ai·云计算·ai编程
重生的黑客1 小时前
Linux开发工具:条件编译、动静态库与 make/makefile 入门
linux·运维·服务器
minji...2 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
w6100104662 小时前
cka-2026-ConfigMap
java·linux·cka·configmap
cc_yy_zh2 小时前
Win10 家庭版找不到Device Guard; 无法处理 VMware Workstation与Device Guard不兼容问题
linux·vmware
航Hang*2 小时前
VMware vSphere 云平台运维与管理基础——第2章(扩展):VMware ESXi 5.5 安装、配置与运维
运维·服务器·github·系统安全·虚拟化
嵌入式吴彦祖3 小时前
Luckfox Pico Ultra W WIFI
linux·嵌入式硬件
SPC的存折3 小时前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_3 小时前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发