优化客户端重新连接过程的服务器事件处理
为了在基于 SSE 的数字队列票应用程序中保持客户端重新连接后的一致性,需要识别和映射每个客户端。虽然 SSE 标准不支持标头传递,但使用查询参数传递令牌是可行的,尽管存在安全问题。替代方案包括使用持久 cookie,但存在绕过风险和隐私问题。另一种方法是通过指纹识别客户端,但可靠性较低。最后,还可以使用 SSE 消息中的 ID 来跟踪丢失的消息,由服务器负责处理。
我正在创建一个“数字队列票”应用程序,人们可以在其中主持队列,而其他人则可以排队。如果你排队,你基本上会看到当前正在服务的 nr、排队人数、预计到达时间等。它是基于网络的,我决定使用 SSE 向每个人推送更改(例如,当前正在服务的 nr 发生更改时)该特定队列。
我需要一种方法来映射/识别每个客户端,这样如果他们断开一段时间然后重新连接,他们仍然会保持其位置一致。我知道如果出现错误,浏览器或 SSE 客户端将自动尝试重新连接。通常会延迟几秒钟,具体取决于浏览器。此外,数据流从断开连接的点继续,因此使用 Last-Event-Id 不会丢失任何消息。
但是,例如,如果用户错误地退出 safari,重新打开它并返回到相同的 URL,则会建立一个新的连接,即它不会“重新连接”。
我考虑过使用令牌或 cookie 来实现此目的。但是,SSE 标准不支持发送标头(或 POST 数据)。仅获取数据和 cookie。我可以传递一个令牌作为查询参数。这是我读过的一些信息:
https://community.apigee.com/questions/28794/best-practices-for-passing-an-access-token-without.html
https://www.rfc-editor.org/rfc/rfc6750#section-2.3
人们讨论与此相关的安全问题,但我认为,由于人们匿名排队,并且令牌仅用于识别重新连接的客户端,这不会成为问题。另外,我负责后端和前端。
使用 cookie 也可能有效,但我对它们的工作原理几乎一无所知。我假设我需要一个持久 cookie 来识别正在“重新连接”的客户端?如果不是,也许我应该使用 WebSockets,或者轮询?我选择SSE的原因是我只需要单向通信。
我对此很陌生,因此非常感谢任何提示!几天来我一直在阅读我能得到的所有内容,但到目前为止还没有找到一个好的解决方案。也许还有其他方法可以完成我想要的事情?
解决方案
我肯定会选择饼干。我还没有在 Go 中尝试过这个,但是这个链接 shows how to set and receive cookies。
缺点是用户可以通过删除 cookie 来绕过它(他们可能有动机这样做,这样他们就可以插队?),并且(至少在欧盟)必须出示“我们使用 cookie” “ 注意。您提到了用户关闭浏览器的情况,因此会话 cookie 是不够的,您需要使用具有过期时间的 cookie。
第二个选择是尝试通过用户代理、IP 地址以及其他标头的组合来“指纹识别”用户。但这是不可靠的,特别是当用户共享代理、VPN 等时(并且有人仍然可以绕过它,例如切换浏览器,或使用允许更改用户代理的插件。)
设置SSE消息中的id,浏览器在重新连接时将发送最后一个事件id标头。 此外,其服务器有责任跟踪由于客户端断开连接而已传递或丢失的消息。
https://www.html5rocks.com/en/tutorials/eventsource/basics/#toc-lastevent-id
今天关于《优化客户端重新连接过程的服务器事件处理》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

- 上一篇
- 转换base64为十六进制

- 下一篇
- 介绍Linux协议栈中常见的网络协议及其功能
-
- Golang · Go问答 | 1年前 |
- 在读取缓冲通道中的内容之前退出
- 139浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 戈兰岛的全球 GOPRIVATE 设置
- 204浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何将结构作为参数传递给 xml-rpc
- 325浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何用golang获得小数点以下两位长度?
- 477浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何通过 client-go 和 golang 检索 Kubernetes 指标
- 486浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 将多个“参数”映射到单个可变参数的习惯用法
- 439浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 将 HTTP 响应正文写入文件后出现 EOF 错误
- 357浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 结构中映射的匿名列表的“复合文字中缺少类型”
- 352浏览 收藏
-
- Golang · Go问答 | 1年前 |
- NATS Jetstream 的性能
- 101浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何将复杂的字符串输入转换为mapstring?
- 440浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 相当于GoLang中Java将Object作为方法参数传递
- 212浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何确保所有 goroutine 在没有 time.Sleep 的情况下终止?
- 143浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 谱乐AI
- 谱乐AI是由青岛艾夫斯科技有限公司开发的AI音乐生成工具,采用Suno和Udio模型,支持多种音乐风格的创作。访问https://yourmusic.fun/,体验智能作曲与编曲,个性化定制音乐,提升创作效率。
- 2次使用
-
- Vozo AI
- 探索Vozo AI,一款功能强大的在线AI视频换脸工具,支持跨性别、年龄和肤色换脸,适用于广告本地化、电影制作和创意内容创作,提升您的视频制作效率和效果。
- 2次使用
-
- AIGAZOU-AI图像生成
- AIGAZOU是一款先进的免费AI图像生成工具,无需登录即可使用,支持中文提示词,生成高清图像。适用于设计、内容创作、商业和艺术领域,提供自动提示词、专家模式等多种功能。
- 2次使用
-
- Raphael AI
- 探索Raphael AI,一款由Flux.1 Dev支持的免费AI图像生成器,无需登录即可无限生成高质量图像。支持多种风格,快速生成,保护隐私,适用于艺术创作、商业设计等多种场景。
- 2次使用
-
- Canva可画AI生图
- Canva可画AI生图利用先进AI技术,根据用户输入的文字描述生成高质量图片和插画。适用于设计师、创业者、自由职业者和市场营销人员,提供便捷、高效、多样化的视觉素材生成服务,满足不同需求。
- 1次使用
-
- GoLand调式动态执行代码
- 2023-01-13 502浏览
-
- 用Nginx反向代理部署go写的网站。
- 2023-01-17 502浏览
-
- Golang取得代码运行时间的问题
- 2023-02-24 501浏览
-
- 请问 go 代码如何实现在代码改动后不需要Ctrl+c,然后重新 go run *.go 文件?
- 2023-01-08 501浏览
-
- 如何从同一个 io.Reader 读取多次
- 2023-04-11 501浏览