HTML5 服务器发送事件(Server-Sent Events)

2024-04-25 13:44

本文主要是介绍HTML5 服务器发送事件(Server-Sent Events),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考:HTML5 服务器发送事件(Server-Sent Events) | 菜鸟教程

一,服务端 main.py

from flask import Flask, Response
import datetime
import timeapp = Flask(__name__)@app.route('/sse')
def send_server_time():def generate_server_time():while True:current_time = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')yield f"data: The server time is: {current_time}\n\n"# 按需调整刷新频率,这里每秒发送一次sleep_duration = 3  # Use a different variable name to avoid conflict with the 'time' moduletime.sleep(sleep_duration)'''配置响应内容类型、缓存控制及启动服务:
使用Response类包装生成器对象,指定mimetype为'text/event-stream',表示这是SSE响应。
添加响应头'Cache-Control': 'no-cache',防止浏览器缓存SSE消息。'''return Response(generate_server_time(), mimetype='text/event-stream',headers={'Cache-Control': 'no-cache','Access-Control-Allow-Origin': '*','Access-Control-Allow-Headers': 'Content-Type,Authorization','Access-Control-Allow-Methods': 'GET,PUT,POST,DELETE,OPTIONS'})if __name__ == '__main__':app.run(debug=False, port=5000)

二,web客户端 client.html

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title>
</head><body><h1>获取服务端更新数据</h1><div id="result"></div><script>// 检测服务器发送事件的浏览器支持情况:if (typeof (EventSource) !== "undefined") {const eventSource = new EventSource('http://127.0.0.1:5000/sse');eventSource.onmessage = function (event) {const data = event.data;console.log('Received server time:', data);// 在此处更新DOM或执行其他操作以展示收到的时间信息document.getElementById("result").innerHTML += event.data + "<br>";};eventSource.onerror = function (error) {console.error('Error occurred with EventSource:', error);};}else {document.getElementById("result").innerHTML = "抱歉,你的浏览器不支持 server-sent 事件...";}</script></body></html>

三,测试

       启动服务端项目:python main.py 

       同时打开多个浏览器client.html

这篇关于HTML5 服务器发送事件(Server-Sent Events)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934850

相关文章

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

SQL Server数据库磁盘满了的解决办法

《SQLServer数据库磁盘满了的解决办法》系统再正常运行,我还在操作中,突然发现接口报错,后续所有接口都报错了,一查日志发现说是数据库磁盘满了,所以本文记录了SQLServer数据库磁盘满了的解... 目录问题解决方法删除数据库日志设置数据库日志大小问题今http://www.chinasem.cn天发

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Python中的异步:async 和 await以及操作中的事件循环、回调和异常

《Python中的异步:async和await以及操作中的事件循环、回调和异常》在现代编程中,异步操作在处理I/O密集型任务时,可以显著提高程序的性能和响应速度,Python提供了asyn... 目录引言什么是异步操作?python 中的异步编程基础async 和 await 关键字asyncio 模块理论

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义