Python Socket 网络通信详解

简介: Python Socket 网络通信详解

Python 模块 Socket 网络通信

文章目录

Python 模块 Socket 网络通信

1. socket介绍

2. Socket 类型

3. Socket 函数

3.1 服务器端 Socket 函数

3.2 客户端 Socket 函数

3.3 公共 Socket 函数

4. Socket 编程思想

4.1 操作ip

4.2 操作端口

4.3 TCP 服务器

4.4 TCP 客户端

5. 练习

5.1 示例1

5.2 示例2

打印程序服务端

打印程序客户端

1. socket介绍

Python 提供了两个基本的 socket 模块:

  • Socket 它提供了标准的BSD Socket API。
  • SocketServer 它提供了服务器重心,可以简化网络服务器的开发。

2. Socket 类型

套接字格式:socket(family, type[,protocal]) 使用给定的套接族,套接字类型,协议编号(默认为0)来创建套接字。

1671096477744.png

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

创建UDP Socket:

sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

3. Socket 函数

  • TCP发送数据时,已建立好TCP链接,所以不需要指定地址,而UDP是面向无连接的,每次发送都需要指定发送给谁。
  • 服务器与客户端不能直接发送列表,元素,字典等带有数据类型的格式,发送的内容必须是字符串数据。

3.1 服务器端 Socket 函数

1671096515832.png

3.2 客户端 Socket 函数

1671096536125.png

3.3 公共 Socket 函数

1671096552301.png

1832b220aa754cd18c504acc7686a560.png

4. Socket 编程思想

4.1 操作ip

127.0.01 本地测试ip
0.0.0.0  局域网可用ip
192.168.1.0 网段
192.168.1.1  网关
192.168.1.255 广播地址
In [1]: import socket
#获取主机名
In [2]: socket.gethostname()
Out[2]: 'localhost.localdomain'
# 通过主机名解析ip
In [3]: socket.gethostbyname('localhost.localdomain')
Out[3]: '127.0.0.1'
In [4]: socket.gethostbyname('localhost')
Out[4]: '127.0.0.1'
In [3]: socket.gethostbyname('www.baidu.com')
Out[3]: '180.101.49.11'
#十进制转换二进制
In [5]: socket.inet_aton('192.168.1.190')
Out[5]: '\xc0\xa8\x01\xbe'
#二进制转换十进制
In [8]: socket.inet_ntoa('\xc0\xa8\x01\xbe')
Out[8]: '192.168.1.190'
#十进制转换二进制
In [11]: socket.inet_pton(socket.AF_INET, '192.168.1.190')
Out[11]: '\xc0\xa8\x01\xbe'
#二进制转换十进制
In [15]: socket.inet_ntop(socket.AF_INET, '\xc0\xa8\x01\xbe')
Out[15]: '192.168.1.190'

4.2 操作端口

应用层端口:1–65535

众所周知的服务端口:1–255

系统端口:256–1023

In [16]: socket.getservbyname('mysql')
Out[16]: 3306
In [17]: socket.getservbyname('http')
Out[17]: 80

4.3 TCP 服务器

1、创建套接字,绑定套接字到本地IP与端口

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

2、开始监听链接

s.listen()

3、进入循环,不断接受客户端的链接请求

While True:
    s.accept()

4、接收客户端传来的数据,并且发送给对方发送数据

s.recv()
s.sendall()

5、传输完毕后,关闭套接字

s.close()

4.4 TCP 客户端

1、创建套接字并链接至远端地址

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

2、链接后发送数据和接收数据

s.sendall()
s.recv()

3、传输完毕后,关闭套接字

5. 练习

5.1 示例1

服务器端代码

import socket
HOST = '192.168.1.100'
PORT = 8001
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind((HOST, PORT))
s.listen(5)
print 'Server start at: %s:%s' %(HOST, PORT)
print 'wait for connection...'
while True:
    conn, addr = s.accept()
    print 'Connected by ', addr
    while True:
        data = conn.recv(1024)
        print data
        conn.send("server received you message.")
# conn.close()

客户端代码

import socket
HOST = '192.168.1.100'
PORT = 8001
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((HOST, PORT))
while True:
    cmd = raw_input("Please input msg:")
    s.send(cmd)
    data = s.recv(1024)
    print data
    #s.close()
$ python soc2.py
Please input msg:ls
server received you message.
Please input msg:hello
server received you message.
$ python test1.py
Server start at: 192.168.211.15:80
wait for connection...
Connected by  ('192.168.211.15', 44079)
ls
hello

5.2 示例2

打印程序服务端

server2.py

#!/usr/bin/env python3
import socket
HOST = '127.0.0.1'  # 标准的回环地址 (localhost)
PORT = 65432        # 监听的端口 (非系统级的端口: 大于 1023)
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
    s.bind((HOST, PORT))
    s.listen()
    conn, addr = s.accept()
    with conn:
        print('Connected by', addr)
        while True:
            data = conn.recv(1024)
            if not data:
                break
            conn.sendall(data)

解说:

  • socket.socket() 创建了一个 socket 对象,并且支持 context manager type,你可以使用 with语句,这样你就不用再手动调用 s.close() 来关闭 socket 了。
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
    pass  # Use the socket object without calling s.close().

bind() 用来关联 socket 到指定的网络接口(IP 地址)和端口号,bind() 方法的入参取决于 socket地址族,在这个例子中我们使用了 socket.AF_INET (IPv4),它将返回两个元素的元组:(host, port)。host可以是主机名称、IP 地址、空字符串,如果使用 IP 地址,host 就应该是 IPv4 格式的字符串,127.0.0.1 是标准的IPv4 回环地址,只有主机上的进程可以连接到服务器,如果你传了空字符串,服务器将接受本机所有可用的 IPv4 地址 端口号应该是1-65535 之间的整数(0是保留的),这个整数就是用来接受客户端链接的 TCP 端口号,如果端口号小于1024,有的操作系统会要求管理员权限。


listen() 方法调用使服务器可以接受连接请求,这使它成为一个「监听中」的 socket

listen() 方法有一个 backlog 参数。它指定在拒绝新的连接之前系统将允许使用的 未接受的连接 数量。从 Python 3.5 开始,这是可选参数。如果不指定,Python 将取一个默认值。如果你的服务器需要同时接收很多连接请求,增加 backlog 参数的值可以加大等待链接请求队列的长度,最大长度取决于操作系统。比如在 Linux 下,参考 /proc/sys/net/core/somaxconn


accept() 方法阻塞并等待传入连接。当一个客户端连接时,它将返回一个新的 socket 对象,对象中有表示当前连接的 conn和一个由主机、端口号组成的 IPv4/v6 连接的元组,这里必须要明白我们通过调用 accept() 方法拥有了一个新的 socket对象。这非常重要,因为你将用这个 socket 对象和客户端进行通信。和监听一个 socket 不同的是后者只用来授受新的连接请求。


从 accept() 获取客户端 socket 连接对象 conn 后,使用一个无限 while 循环来阻塞调用conn.recv(),无论客户端传过来什么数据都会使用 conn.sendall() 打印出来,如果 conn.recv()方法返回一个空 byte 对象(b’'),然后客户端关闭连接,循环结束,with 语句和 conn 一起使用时,通信结束的时候会自动关闭socket 链接。

打印程序客户端

#!/usr/bin/env python3
import socket
HOST = '127.0.0.1'  # 服务器的主机名或者 IP 地址
PORT = 65432        # 服务器使用的端口
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
    s.connect((HOST, PORT))
    s.sendall(b'Hello, world')
    data = s.recv(1024)
print('Received', repr(data))

运行:

第一步

$ python3.8 server1.py

第二步:

$ python3.8 client2.py 
Received b'Hello, world'

第三步

$ python3.8 server1.py
Connected by ('127.0.0.1', 47816)

参考:

相关文章
|
3月前
|
机器学习/深度学习 算法 量子技术
GQNN框架:让Python开发者轻松构建量子神经网络
为降低量子神经网络的研发门槛并提升其实用性,本文介绍一个名为GQNN(Generalized Quantum Neural Network)的Python开发框架。
65 4
GQNN框架:让Python开发者轻松构建量子神经网络
|
8天前
|
JavaScript Java 大数据
基于python的网络课程在线学习交流系统
本研究聚焦网络课程在线学习交流系统,从社会、技术、教育三方面探讨其发展背景与意义。系统借助Java、Spring Boot、MySQL、Vue等技术实现,融合云计算、大数据与人工智能,推动教育公平与教学模式创新,具有重要理论价值与实践意义。
|
2月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
125 18
|
3月前
|
JSON 网络安全 数据格式
Python网络请求库requests使用详述
总结来说,`requests`库非常适用于需要快速、简易、可靠进行HTTP请求的应用场景,它的简洁性让开发者避免繁琐的网络代码而专注于交互逻辑本身。通过上述方式,你可以利用 `requests`处理大部分常见的HTTP请求需求。
316 51
|
2月前
|
数据采集 存储 数据可视化
Python网络爬虫在环境保护中的应用:污染源监测数据抓取与分析
在环保领域,数据是决策基础,但分散在多个平台,获取困难。Python网络爬虫技术灵活高效,可自动化抓取空气质量、水质、污染源等数据,实现多平台整合、实时更新、结构化存储与异常预警。本文详解爬虫实战应用,涵盖技术选型、代码实现、反爬策略与数据分析,助力环保数据高效利用。
122 0
|
10月前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
839 55
|
9月前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
492 5
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
3月前
|
存储 监控 算法
基于 Python 跳表算法的局域网网络监控软件动态数据索引优化策略研究
局域网网络监控软件需高效处理终端行为数据,跳表作为一种基于概率平衡的动态数据结构,具备高效的插入、删除与查询性能(平均时间复杂度为O(log n)),适用于高频数据写入和随机查询场景。本文深入解析跳表原理,探讨其在局域网监控中的适配性,并提供基于Python的完整实现方案,优化终端会话管理,提升系统响应性能。
85 4
|
5月前
|
调度 Python
探索Python高级并发与网络编程技术。
可以看出,Python的高级并发和网络编程极具挑战,却也饱含乐趣。探索这些技术,你将会发现:它们好比是Python世界的海洋,有穿越风暴的波涛,也有寂静深海的奇妙。开始旅途,探索无尽可能吧!
114 15
|
6月前
|
数据采集 存储 监控
Python 原生爬虫教程:网络爬虫的基本概念和认知
网络爬虫是一种自动抓取互联网信息的程序,广泛应用于搜索引擎、数据采集、新闻聚合和价格监控等领域。其工作流程包括 URL 调度、HTTP 请求、页面下载、解析、数据存储及新 URL 发现。Python 因其丰富的库(如 requests、BeautifulSoup、Scrapy)和简洁语法成为爬虫开发的首选语言。然而,在使用爬虫时需注意法律与道德问题,例如遵守 robots.txt 规则、控制请求频率以及合法使用数据,以确保爬虫技术健康有序发展。
769 31

热门文章

最新文章

推荐镜像

更多