位置: IT常识 - 正文

由浅入深介绍 Python Websocket 编程(由浅入深英语怎么说)

编辑:rootadmin
由浅入深介绍 Python Websocket 编程 目录1. 为什么使用 Websocket ?1.1 websocket 协议简介1.2 基本原理2. 如何用 Python 搭建 Websocket 服务2.1 安装websockets包2.2 编写 server 端代码3. Python websocket 客户端实现代码4. Javascript websocket 客户端实现代码5. 测试websocket6. 服务器向客户端广播消息1. 为什么使用 Websocket ?1.1 websocket 协议简介

推荐整理分享由浅入深介绍 Python Websocket 编程(由浅入深英语怎么说),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:由浅入深的话题,由浅入深英语,由浅入深英语翻译,由浅入深英语怎么说,由浅入深英语怎么说,由浅入深介绍了,由浅入深介绍了,由浅入深介绍了,内容如对您有帮助,希望把文章链接给更多的朋友!

Websocket协议是对http的改进,可以实现client 与 server之间的双向通信; websocket连接一旦建立就始终保持,直到client或server 中断连接,弥补了http无法保持长连接的不足,方便了客户端应用与服务器之间实时通信。

适用场景html页面实时更新, 客户端的html页面内,用` javascript` 与 server 建立websocket连接,实现页面内容的实时更新。Websocket 非常适合网页游戏、聊天、证券交易等实时应用。要求保持长连接的实时通信的应用场景。 如基于位置的服务应用,物联网,多方协作软件,在线教育,带社交属性的手机APP等。

实时更新数据场景,为什么不使用AJAX? AJAX 采用http, 如果要实时更新页面,则需要不断地发送http 请求,无论是否有数据更新,产生大量冗余通信流量。而websocket是长连接双向通信,有数据更新时,服务器向客户机发送通知。

1.2 基本原理

基于TCP,一次握手就能建立连接,支持双向通信,可保持长连接。

WebSocket 握手请求消息示例::

GET /chat HTTP/1.1Host: normal-website.comSec-WebSocket-Version: 13Sec-WebSocket-Key: wDqumtseNBJdhkihL6PW7w==Connection: keep-alive, UpgradeCookie: session=KOsEJNuflw4Rd9BDNrVmvwBF9rEijeE2Upgrade: websocket

如果 Server 接收连接,返回响应

HTTP/1.1 101 Switching ProtocolsConnection: UpgradeUpgrade: websocketSec-WebSocket-Accept: 0FFP+2nmNIf/h+4BP36k9uzrYGk=

响应码为101,表示切换为websocket 协议。

websocket 已得到主流浏览器,各编程语言的广泛支持,基本都提供了WebSocket高阶编程API,在一般场合下,可以替代socket低阶函数编程。python 提供了更简洁的编程实现方式。下面展示了实例代码方式,说明如何开发 Python websocket 服务器代码,python websocket 客户端, 以及javascript websocket 代码。

2. 如何用 Python 搭建 Websocket 服务

python 第3方库 websockets 提供了websocket 实现框架,支持asyncio, 性能强大,稳定性好,可以用于生产环境。

2.1 安装websockets包pip install websockets2.2 编写 server 端代码

Websocket服务端代码是面向多用户的长连接,因此本文采用了python3.7 版本的 asyncio 异步方式编写 websocket server 代码。

服务端也可使用 ThreadPoolExecutor 线程池方式同时处理多连接的场景,用户较多时,性能明显不如asyncio异步方式。

websockets 模块 server端的主要方法:

recv() 收消息send() 发送消息serve() 创建 server 对象由浅入深介绍 Python Websocket 编程(由浅入深英语怎么说)

实现步骤:

编写websocket 异步任务处理函数handler创建1个websocket server 对象异步运行 server对象

websocket 地址格式:

ws://主机地址:端口号wss://主机地址:端口号, wss表示此连接为https 连接。

下面是具体的代码 server.py

#!/usr/bin/python3# 主要功能:创建1个基本的websocket server, 符合asyncio 开发要求import asyncioimport websocketsfrom datetime import datetimeasync def handler(websocket): data = await websocket.recv() reply = f"Data received as \"{data}\". time: {datetime.now()}" print(reply) await websocket.send(reply) print("Send reply")async def main(): async with websockets.serve(handler, "localhost", 9999): await asyncio.Future() # run foreverif __name__ == "__main__": asyncio.run(main())

服务端handler函数代码还有1种写法,适用性更好。

async def handler(websocket): async for message in websocket: reply = f"Data received as \"{message}\". time: {datetime.now()}" print(reply) await websocket.send(reply)

Websocket协议本身有心跳机制、连接检测机制,服务端无须关心客户端状态,一旦有异常,会自动断开连接。

Websockets提供了交互式测试命令,现在可以快速测试一下服务端是否能正常工作: (1) 启动服务器: python server.py (2) 通过命令行连接服务端,并向发送hello, world 消息,可以看到,收到了服务器的响应。

D:\workplace\python\projects\websock>python -m websockets ws://localhost:9999Connected to ws://localhost:9999.> hello, world< Data received as "hello, world". time: 2023-04-01 09:24:14.787357Connection closed: 1000 (OK).

当然实际应用时,应按下面步骤来编写客户端代码。

3. Python websocket 客户端实现代码

websockets 客户端提供的主要方法:

connect() 建立与服务器的连接recv(), send() 收发消息close() 显式地关闭连接

下面看一下示例 client.py

import asyncioimport websocketsimport timeasync def ws_client(url): for i in range(1, 40): async with websockets.connect(url) as websocket: await websocket.send("Hello, I am PyPy.") response = await websocket.recv() print(response) time.sleep(1)asyncio.run(ws_client('ws://localhost:9999'))4. Javascript websocket 客户端实现代码

目前主流的浏览器都支持websocket协议。

Javascript websocket 对象的主要属性与方法: 请参考菜鸟教程的这篇文章:https://www.runoob.com/html/html5-websocket.html

示例代码: client.html

<!DOCTYPE HTML><html><head> <meta charset="utf-8"> <title>websocket demo</title> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/4.3.1/css/bootstrap.min.css"><script src="https://cdn.staticfile.org/jquery/3.2.1/jquery.min.js"></script><script src="https://cdn.staticfile.org/popper.js/1.15.0/umd/popper.min.js"></script> <script src="https://cdn.staticfile.org/twitter-bootstrap/4.3.1/js/bootstrap.min.js"></script> <script type="text/javascript"> function WebSocketTest() { text = document.getElementById("div_text"); if ("WebSocket" in window) { // 打开一个 web socket var ws = new WebSocket("ws://localhost:9999/handler"); ws.onopen = function () { // Web Socket 已连接上,使用 send() 方法发送数据 ws.send("Javscript发送的数据"); text.innerHTML = "数据发送中..."; alert("数据发送中..."); }; ws.onmessage = function (evt) { var received_msg = evt.data; text.innerHTML = "收到的数据:" + received_msg; alert("数据已接收..."); }; ws.onclose = function () { // 关闭 websocket text.innerHTML = "连接已关闭..."; alert("连接已关闭..."); }; } else { // 浏览器不支持 WebSocket alert("您的浏览器不支持 WebSocket!"); } } </script></head><body> <div class="col-md-6 m-5 p-2" id="div_ws"> <a class="btn btn-primary" href="javascript:WebSocketTest()">连接WebSocket</a> </div> <div class="col-md-6 border border-primary mx-5 p-2 " id="div_text" style="margin:20px;height:100px;"> display communicate text </div></body></html>5. 测试websocket

上述3个文件都放在同1个目录下,打开两个终端窗口,先运行server.py, 再运行 client,py。 Output结果 在chrome 或edge 中运行client.html, 可以看到websocket 连接建立,发送,接收,关闭各阶段的状态。 能够看到,服务器与客户端之间的通信是双向的,而且是长连接,客户端断开后,服务器仍然保持侦听状态,而且不需要accept操作。websocket发送、接收文件也不需要 socket 对发送窗口 buffer 进行控制,因此是 socket 开发非常好的替代。

注:Python异步websocket服务器最终性能与代码质量、服务器硬件、网络等紧密相关,可以使用 Websocket-benchmarker 测试工具来测试服务器。

6. 服务器向客户端广播消息

websockets 模块支持向所有连接的客户广播消息, 用1个简单的例子来演示,实现步骤:

保存每个 websocket 客户连接向每个客户发送消息

将前面的server,.py 代码修改后如下:

#!/usr/bin/python3# 主要功能:创建1个基本的websocket server, 符合asyncio 开发要求import asyncioimport websocketsfrom datetime import datetimeCONNECTIONS = set()async def send(websocket, message): try: await websocket.send(message) except websockets.ConnectionClosed: passasync def broadcast(message=""): # 向队列中的每个连接发送消息, 广播10次 for i in range(0,10): message = f"Broadcast: New user joined, now time is {datetime.now()}" if CONNECTIONS : # asyncio.wait doesn't accept an empty list await asyncio.wait([ asyncio.create_task(send(websocket, message)) for websocket in CONNECTIONS ]) await asyncio.sleep(30) #每次广播间隔async def handler(websocket): CONNECTIONS.add(websocket) # 保存客户连接至集合 try: # do other things await websocket.wait_closed() finally: CONNECTIONS.remove(websocket)async def main(): async with websockets.serve(handler, "localhost", 9998): await asyncio.Future() # run forever loop = asyncio.get_running_loop() #获取当前event_loop对象 loop.create_task(broadcast()) # 添加新的异步广播任务if __name__ == "__main__": asyncio.run(main())

注: 本例broadcast() 方法每30秒,就向全部用户发送广播。实际应用时可以保持永久循环

本文链接地址:https://www.jiuchutong.com/zhishi/296087.html 转载请保留说明!

上一篇:HTTP 错误 500.19- Internal Server Error 错误解决方法

下一篇:vue3使用nextTick(vue3使用ref获取元素)

  • 金山文档ppt怎么转换成ppt(金山文档ppt怎么添加图片)

    金山文档ppt怎么转换成ppt(金山文档ppt怎么添加图片)

  • 闲鱼拉黑了还能看到对方卖的东西吗(闲鱼拉黑了还能评价对方吗)

    闲鱼拉黑了还能看到对方卖的东西吗(闲鱼拉黑了还能评价对方吗)

  • 华为手机怎么找回删除的照片(华为手机怎么找到对方的手机位置)

    华为手机怎么找回删除的照片(华为手机怎么找到对方的手机位置)

  • iphone防水等级(iphone13防水等级)

    iphone防水等级(iphone13防水等级)

  • 抖音视频时间多长(抖音视频下载app)

    抖音视频时间多长(抖音视频下载app)

  • 蓝牙键盘用着用着就无法使用了(蓝牙键盘反应迟钝怎么解决)

    蓝牙键盘用着用着就无法使用了(蓝牙键盘反应迟钝怎么解决)

  • 苹果7屏幕尺寸(苹果7屏幕尺寸对照表)

    苹果7屏幕尺寸(苹果7屏幕尺寸对照表)

  • 微信文件传输助手怎么检测好友删除(微信文件传输助手在哪里打开)

    微信文件传输助手怎么检测好友删除(微信文件传输助手在哪里打开)

  • 电池坏了怎么修复(电池坏了怎么修复小妙招)

    电池坏了怎么修复(电池坏了怎么修复小妙招)

  • 可以申请两个微信号吗(能不能申请2个微信号)

    可以申请两个微信号吗(能不能申请2个微信号)

  • 勿扰模式有来电记录吗(勿扰模式来电话会震动吗)

    勿扰模式有来电记录吗(勿扰模式来电话会震动吗)

  • 华为手机上的月亮标志怎么关(华为手机上的月牙怎么取消)

    华为手机上的月亮标志怎么关(华为手机上的月牙怎么取消)

  • 抖音的音浪是每个月清零吗(抖音的音浪每天都可以提现吗)

    抖音的音浪是每个月清零吗(抖音的音浪每天都可以提现吗)

  • 苹果11pro手机有几个扬声器(苹果11pro手机有几种颜色)

    苹果11pro手机有几个扬声器(苹果11pro手机有几种颜色)

  • 闲鱼单产品永久禁言是什么意思(闲鱼长期执行的期限是多少)

    闲鱼单产品永久禁言是什么意思(闲鱼长期执行的期限是多少)

  • 荣耀30参数详细参数(荣耀30参数详细价格)

    荣耀30参数详细参数(荣耀30参数详细价格)

  • 什么是京东自营商品(什么是京东自营商品京东卡怎么用)

    什么是京东自营商品(什么是京东自营商品京东卡怎么用)

  • 手机软件卸载不了怎么办(手机软件卸载不干净)

    手机软件卸载不了怎么办(手机软件卸载不干净)

  • 台式电脑卡死怎么解决(台式电脑直接卡死)

    台式电脑卡死怎么解决(台式电脑直接卡死)

  • 发说说怎么显示拍摄于(发说说怎么显示拍摄地点,天气,时间)

    发说说怎么显示拍摄于(发说说怎么显示拍摄地点,天气,时间)

  • word为什么编辑不了(word为什么编辑不了公式)

    word为什么编辑不了(word为什么编辑不了公式)

  • 苹果7耗电快怎么办(苹果7耗电快怎么解决)

    苹果7耗电快怎么办(苹果7耗电快怎么解决)

  • 天籁usb设置方法(天籁usb设置方法图解)

    天籁usb设置方法(天籁usb设置方法图解)

  • 微信怎么加好友(微信怎么加好友设置权限)

    微信怎么加好友(微信怎么加好友设置权限)

  • 显卡风扇转但是屏幕没反应(显卡风扇转但是显示器不亮)

    显卡风扇转但是屏幕没反应(显卡风扇转但是显示器不亮)

  • 鸿蒙系统中智能充电模式和反向充电功能怎么使用?(鸿蒙系统智能设备怎么开启)

    鸿蒙系统中智能充电模式和反向充电功能怎么使用?(鸿蒙系统智能设备怎么开启)

  • 如何用 chatGPT,给大家来一个自我介绍(在国内如何用ChatGPT)

    如何用 chatGPT,给大家来一个自我介绍(在国内如何用ChatGPT)

  • 增值税电子发票查询平台
  • 应收出口退税金额无法收回怎么做账?
  • 小微企业免税销售额是按1%还是3%
  • 预收贷方余额表示什么意思
  • 有限合伙企业有经营权吗
  • 劳务派遣差额计税公式
  • 生产设备购买交付会计分录
  • 调账以前年度损益调整如何结转
  • 工会劳动保护费不能列支劳保用品
  • 已付款未收到发票怎么做分录
  • 发票限额是含税还是不含
  • 支付运费价税合计
  • 防伪税控维护费会计分录
  • 什么公司不需要融资
  • 买金税盘怎么做账,抵扣的时候
  • 地税纳税人编码是什么
  • 陕西省水利基金的税率
  • 生产企业销售原材料所取得的收入属于( )
  • 小规模纳税人别人开了专票怎样处理
  • 无票收入的账务怎么处理
  • 完工百分比法确认收入应注意的问题
  • PRISMSTA.EXE - PRISMSTA是什么进程 有什么用
  • unsupportedfirsthd解决办法
  • 房产税存在往期未申报信息怎么处理
  • 华为mate50pro怎么读
  • vue+cesium怎么实现地图的加载
  • 购货款先到支付后付款
  • 试用期人员工资财务记账
  • 应付债券利息费用
  • e卡 叠加
  • php计算数组中值怎么算
  • 金蝶kis迷你版银行存款二级科目
  • vue中elementui怎么用
  • 未分配利润与净利润关系
  • html做超链接
  • emerge命令
  • 终止经营净利润含义
  • 什么是财务报表分析,方法有哪些
  • sql server nullif
  • sql server定时作业
  • 企业处置子公司
  • 房产税是怎么样
  • 工程异地施工缴什么税
  • 代扣代缴个人所得税手续费返还政策
  • 购买会计软件如何入账
  • 民间非盈利组织会计制度核算的基础
  • 押金为什么要一个月才退
  • 提取的安全生产费
  • 小额 无发票
  • 发行长期债券计入什么科目
  • 资金结存属于资产类吗
  • 预计所有者权益增长率
  • 专票多少钱
  • 小规模升级一般纳税人有什么好处
  • mysql5.6免安装版配置
  • linux防御
  • CentOS6 32/64位安装Adobe Flash Player组件的方法
  • win10预览版选哪个
  • xp系统怎么删除应用程序
  • autorun.inf在win10
  • linux系统中
  • 本地电脑的网卡物理地址
  • linux 查看磁盘io繁忙
  • win10可以关闭的功能
  • win8注册表损坏进不了系统
  • el-menu-item
  • windows visual studio 基于openGL的粒子系统设计
  • 我吐槽你
  • AddForceAtPosition方法:增加刚体点作用力
  • javascript的对象主要包括
  • python基础开发
  • python不能用
  • 学习雷锋好榜样
  • 前端头像裁剪
  • unity gpu优化
  • 陕西税务平台
  • 街道税务所职责和任务
  • 查税务在哪里查
  • 智能财税是什么行业
  • 一般纳税人认定书
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设