我正在创建一个“数字排队票”应用程序,人们可以在其中主持队列,其他人排队。如果您排队,您基本上会看到当前正在服务的 nr、排队的人数、ETA 等。它是基于网络的,我决定使用 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 的原因是我只需要单向通信。
我对此很陌生,所以任何提示都表示赞赏!几天来一直在阅读所有我能得到的东西,但到目前为止还没有找到一个好的解决方案。也许还有其他方法可以完成我想要的?
明月笑刀无情
DIEA
相关分类