Flask 作为一个全栈架构,如果你只会 python,而不懂 javascript 的前端知识,似乎是无法支撑起你的 web 梦想的,比如,一个简单的页面 局部刷新 功能,你就需要用到 ajax 的知识,当然,你还可以使用 HTML5 的新特性 —— websocket功能,好在 flask 还提供了一个 flask-socketio 插件,本文我们就探讨一下这个 flask-scoketio插件的用法。
理解 websocket 协议
- HTTP 协议只能通过客户端发起请求来与客户端进行通讯 —— 这是一个缺陷。
- 通过websocket 协议,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。
websocket 协议特性
- 建立在 TCP 协议之上,服务器端的实现比较容易。
- 与 HTTP 协议有着良好的兼容性。默认端口也是80和443,并且握手阶段采用 HTTP 协议,因此握手时不容易屏蔽,能通过各种 HTTP 代理服务器。
- 数据格式比较轻量,性能开销小,通信高效。
- 可以发送文本,也可以发送二进制数据。
- 没有同源限制,客户端可以与任意服务器通信。
- 协议标识符是ws(如果加密,则为wss),服务器网址就是 URL。
使用 flask-socketio
安装插件
1 | 复制代码pip install flask-socketio |
项目结构
本文是在 《基于 flask 的 CRUD 操作》 的基础上增加了 webscoket 的功能,使用的是 init_app()
的形式加载 flask-socketio 插件,和网上的大多数教程稍有不同。
1 | 复制代码flask-wtf-crud/ |
将 flask-socketio 引入项目
修改 manage.py 内容
1 | 复制代码# -*- coding:utf-8 -*- |
修改 app/__init__.py 内容
1 | 复制代码# -*- coding:utf-8 -*- |
当前蓝图的 views.py
1 | 复制代码# -*- coding:utf-8 -*- |
———- 以上内容是后端的内容,以下内容是将是前段的内容 ———-
crud.js 内容
1 | 复制代码$(document).ready(function () { |
显示结果
每次打开网页,会显示服务端发送的内容——“试图连接客户端!”,其后,客户端返回给服务端——“我已连接上服务端!”,而后又被服务端返回给客户端显示。
以下的表格内容显示数据局里的内容,每 5 秒局部刷新一次表格内容。
服务器后端 log 日志内容如下:
总结
- 由于 flask 架构具有上下文的限制,在数据库里 增加删改 内容的时候,表格的内容没有变化——尽管局部已经进行了刷新。要想显示变化后的数据库内容,必须得重新启动一下 flask 服务。
- 就整体的部署来说,在 flask 项目里添加 websocket 协议,显得项目较重,实现一个局部刷新的功能还是用 ajax 比较简单。
- 欢迎大侠能够给我的项目提出修改意见,先行感谢!!!
参考
本文转载自: 掘金