【Python之旅】第五篇(一):Python Socket通信原理

简介:

1.Socket

    socket也称作“套接字”,用于描述IP地址和端口,是一个通信链的句柄。应用程序通常通过“套接字”向网络发出请求或者应答网络请求。可以列举中国移动或者是中国电信等的电话客服,当然,也可以看下面的图片来作形象的说明。

    socket起源于Unix,而Unix/Linux基本哲学之一就是:一切皆文件,即都可以用“打开open—>读写write/read—>关闭close”模式来操作。Socket就是该模式的一个实现,socket即是一种特殊的文件,一些socket函数就是对其进行的操作(读/写IO、打开、关闭)。

    可以看下面的图示来形象说明:

wKioL1YPYV-ASBXxAAG4ZzVVxxg286.jpg

2.Socket编程

(1)Socket服务器编程

    主要包括下面的几步:

1.打开socket

2.绑定到一个地址和端口

3.侦听进来的连接

4.接受连接

5.读写数据


(2)Socket客户端编程

    主要包括下面的几步:

1.打开socket

2.连接到一个地址和端口

3.读写数据


3.Socket类型

    Socket从类型上分,可以有以下几种:

socket类型 适用范围 说明
socket.AF_UNIX 只能够用于单一的Unix系统进程间通信 不能在不同主机之间通信
socket.AF_INET 服务器之间网络通信 目前常用的就是这种
socket.AF_INET6 IPv6 由于IPv6未推广,也少用

    上面是socket的类型,细分的话还有socket的数据包类型,图示如下:

wKiom1YPZeHgW_wqAAHUjUnzsUk309.jpg

    常用的是第一种和第二种,即for TCP和for UDP的类型,当然socket.SOCK_RAW也需要注意,因为它可以构造IP头,因此沿着这个思路,可以合伪造不同源IP地址的数据包,以对一些中小型企业服务器发动Dos攻击。


4.Socket函数

    对socket进行相关操作如“读/写IO、打开、关闭”的函数即是Socket函数,可以看下面的图示:

wKioL1YPZkWQ7j2kAAKpXDeEktM173.jpgwKiom1YPZlnxRJORAACWrVeJL3E983.jpg

wKiom1YPZoLBYyhJAAIovv5QHqs076.jpgwKiom1YPZp-AtJwoAAIlQjSur0Y883.jpg    只需要记住常用的就可以,即通常会在Server端和Client端中编程会用到的,可以见下面的例子。


5.Socket例子

    下面就写一个单线程非交互式的socket,在本机里实现通信就好了。

Server端:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import  socket                #导入socket类
 
HOST = ''                      #定义侦听本地地址口(多个IP地址情况下),这里表示侦听所有,也可以写成 0.0 . 0.0
PORT =  50007                  #Server端开放的服务端口
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)    #选择Socket类型和Socket数据包类型
s.bind((HOST, PORT))         #绑定IP地址和端口
s.listen( 1 )                  #定义侦听数开始侦听(实际上并没有效果)
conn, addr = s.accept()      #定义实例,accept()函数的返回值可以看上面的socket函数说明
 
print  'Connected by' , addr
while  1 :
     data = conn.recv( 1024 )    #接受套接字的数据
     if  not data: break          #如果没有数据接收,则断开连接
     print  'revc:' ,data        #发送接收到的数据
     conn.sendall(data)        #发送接收到的数据
conn.close()                      #关闭套接字


Client端:

1
2
3
4
5
6
7
8
9
10
11
import  socket
 
HOST =  '192.168.1.13'         #定义目标主机名
PORT =  50007                  #定义目标主机开放服务端口号
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  #选择Socket类型和Socket数据包类型 
s.connect((HOST, PORT))      #连接到目标主机的socket(套接字)中
 
s.sendall( 'Hello, world!' )   #发送数据
data = s.recv( 1024 )          #接收数据
s.close()                    #关闭socket
print  'Received' , repr(data)


演示:

步骤1:Server端运行服务端程序

1
2
xpleaf@xpleaf-machine:/mnt/hgfs/Python/day5$ python server4.py 
===>光标在此处处于等待状态

步骤2:Client端运行客户端程序

1
2
xpleaf@xpleaf-machine:/mnt/hgfs/Python/day5$ python client4.py 
Received 'Hello, world!    ===>收到服务端返回的数据

步骤3:在Server端中观察现象

1
2
3
xpleaf@xpleaf-machine:/mnt/hgfs/Python/day5$ python server4.py 
Connected by ( '192.168.1.13' 52641 )    ===>有客户端连接进来, 52641 为Client的随机端口号
revc: Hello, world!                     ===>收到来自Client端的数据



本文转自 xpleaf 51CTO博客,原文链接:http://blog.51cto.com/xpleaf/1700032,如需转载请自行联系原作者
相关文章
|
5月前
|
机器学习/深度学习 监控 数据挖掘
Python 高效清理 Excel 空白行列:从原理到实战
本文介绍如何使用Python的openpyxl库自动清理Excel中的空白行列。通过代码实现高效识别并删除无数据的行与列,解决文件臃肿、读取错误等问题,提升数据处理效率与准确性,适用于各类批量Excel清理任务。
562 0
|
5月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
562 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
6月前
|
机器学习/深度学习 文字识别 Java
Python实现PDF图片OCR识别:从原理到实战的全流程解析
本文详解2025年Python实现扫描PDF文本提取的四大OCR方案(Tesseract、EasyOCR、PaddleOCR、OCRmyPDF),涵盖环境配置、图像预处理、核心识别与性能优化,结合财务票据、古籍数字化等实战场景,助力高效构建自动化文档处理系统。
1622 0
机器学习/深度学习 算法 自动驾驶
1176 0
|
6月前
|
数据可视化 Linux iOS开发
Python脚本转EXE文件实战指南:从原理到操作全解析
本教程详解如何将Python脚本打包为EXE文件,涵盖PyInstaller、auto-py-to-exe和cx_Freeze三种工具,包含实战案例与常见问题解决方案,助你轻松发布独立运行的Python程序。
1588 2
|
6月前
|
设计模式 缓存 运维
Python装饰器实战场景解析:从原理到应用的10个经典案例
Python装饰器是函数式编程的精华,通过10个实战场景,从日志记录、权限验证到插件系统,全面解析其应用。掌握装饰器,让代码更优雅、灵活,提升开发效率。
428 0
|
7月前
|
数据采集 消息中间件 并行计算
Python多线程与多进程性能对比:从原理到实战的深度解析
在Python编程中,多线程与多进程是提升并发性能的关键手段。本文通过实验数据、代码示例和通俗比喻,深入解析两者在不同任务类型下的性能表现,帮助开发者科学选择并发策略,优化程序效率。
586 1
|
7月前
|
数据采集 Web App开发 JSON
Python爬虫基本原理与HTTP协议详解:从入门到实践
本文介绍了Python爬虫的核心知识,涵盖HTTP协议基础、请求与响应流程、常用库(如requests、BeautifulSoup)、反爬应对策略及实战案例(如爬取豆瓣电影Top250),帮助读者系统掌握数据采集技能。
637 0
|
8月前
|
存储 数据安全/隐私保护 开发者
Python深浅拷贝全解析:从原理到实战的避坑指南
在Python开发中,深浅拷贝是处理对象复制的关键概念。直接赋值仅复制引用,修改副本会影响原始数据。浅拷贝(如切片、copy方法)创建新容器但共享嵌套对象,适用于单层结构或需共享子对象的场景;而深拷贝(copy.deepcopy)递归复制所有层级,确保完全独立,适合嵌套结构或多线程环境。本文详解二者原理、实现方式及性能考量,帮助开发者根据实际需求选择合适的拷贝策略,避免数据污染与性能浪费。
464 1

推荐镜像

更多