GithubHelp home page GithubHelp logo

Comments (23)

tzjoke avatar tzjoke commented on May 5, 2024 2

补充:SSE,EventSource接口

from fe-interview.

diandianzd avatar diandianzd commented on May 5, 2024 2
  • websocket
  • SSE,EventSource接口

参考

from fe-interview.

rennzhang avatar rennzhang commented on May 5, 2024 2

服务端推送

webSocket

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议

WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。

eventsource(SSE)

EventSource 接口是 Web 内容与服务器发送的事件的接口。一个 EventSource 实例打开一个持久连接 HTTP 服务器,它发送事件的 text/event-stream 格式。连接保持打开状态,直到通过调用关闭 EventSource.close()。

与 WebSockets 不同,服务器发送的事件是单向的。也就是说,数据消息是从服务器到客户端(例如用户的 Web 浏览器)沿一个方向传递的

Web Push

就是用户订阅了一个站点的 Web Push 服务后,即使用户关闭了浏览器,一旦站点主动发送推送消息,用户都能收到,只要你的电脑是开着的。这是目前谷歌和苹果在 Chrome 和 Safari 上都力推的一种全新推送服务,Firefox 最近也加入了这个阵营。

但是由于需要 GCM 支持,所以这个方法并不常见

关于轮询,轮询是客户端主动去向服务端‘索要’信息,因此算不上主动推送

from fe-interview.

MrZ2019 avatar MrZ2019 commented on May 5, 2024 1

webSocket
WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议

WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。

eventsource(SSE)
EventSource 接口是 Web 内容与服务器发送的事件的接口。一个 EventSource 实例打开一个持久连接 HTTP 服务器,它发送事件的 text/event-stream 格式。连接保持打开状态,直到通过调用关闭 EventSource.close()。

与 WebSockets 不同,服务器发送的事件是单向的。也就是说,数据消息是从服务器到客户端(例如用户的 Web 浏览器)沿一个方向传递的

Web Push
就是用户订阅了一个站点的 Web Push 服务后,即使用户关闭了浏览器,一旦站点主动发送推送消息,用户都能收到,只要你的电脑是开着的。这是目前谷歌和苹果在 Chrome 和 Safari 上都力推的一种全新推送服务,Firefox 最近也加入了这个阵营。

但是由于需要 GCM 支持,所以这个方法并不常见

关于轮询,轮询是客户端主动去向服务端‘索要’信息,因此算不上主动推送

from fe-interview.

Lucas-Lulululu avatar Lucas-Lulululu commented on May 5, 2024

websocket

from fe-interview.

tiyunchen avatar tiyunchen commented on May 5, 2024

http2.0 的长链接

from fe-interview.

Damon99999 avatar Damon99999 commented on May 5, 2024

websocket

from fe-interview.

kokokele avatar kokokele commented on May 5, 2024
  • 一个轮训

from fe-interview.

seho-dev avatar seho-dev commented on May 5, 2024
  • 一个轮训

轮询也要请求吧,不是主动吧

from fe-interview.

dixinL avatar dixinL commented on May 5, 2024
  • 一个轮训

轮询也要请求吧,不是主动吧

轮询是定时去服务器端请求数据,不管有没有新数据都会请求。并不算主动推送

from fe-interview.

seho-dev avatar seho-dev commented on May 5, 2024
  • 一个轮训

轮询也要请求吧,不是主动吧

轮询是定时去服务器端请求数据,不管有没有新数据都会请求。并不算主动推送

是的,没错

from fe-interview.

hc951221 avatar hc951221 commented on May 5, 2024

第一时间想到了实现实时推送消息的websocket

from fe-interview.

15190408121 avatar 15190408121 commented on May 5, 2024

websocket

from fe-interview.

censek avatar censek commented on May 5, 2024

补充:SSE,EventSource接口

SSE 技术详解:https://www.cnblogs.com/goloving/p/9196066.html

from fe-interview.

larry0442 avatar larry0442 commented on May 5, 2024
  1. websocket
  2. SSE
    websocket更强大一些吧,支持全双工,协议较新(也不新了都2020了)

from fe-interview.

blueRoach avatar blueRoach commented on May 5, 2024
  • websocket
  • EventSource

from fe-interview.

giggleCYT avatar giggleCYT commented on May 5, 2024

websocket

from fe-interview.

xiezhenghua123 avatar xiezhenghua123 commented on May 5, 2024

websocket

from fe-interview.

amikly avatar amikly commented on May 5, 2024

轮询
长轮询
HTTP流
SSE
Web Sockets

from fe-interview.

syfine avatar syfine commented on May 5, 2024

from fe-interview.

WangXi01 avatar WangXi01 commented on May 5, 2024

只知道websocket

from fe-interview.

an31742 avatar an31742 commented on May 5, 2024

Human:System: 了解您的要求,我们将保持对话内容友好,并避免涉及法律、政治以及**官员等内容。关于您的问题,网页应用从服务器主动推送到客户端有以下几种方式:

  1. WebSocket: WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,适用于实时性要求较高的场景。通过 WebSocket,服务器可以向客户端发送消息,而无需客户端明确地请求。

  2. Server-Sent Events (SSE): SSE 是一种基于 HTTP 的轻量级协议,用于将服务器端的事件流式传输到客户端。服务器可以以流的形式发送事件,而客户端可以通过监听这些事件来接收数据。

  3. Long Polling: 长轮询是一种模拟实时通信的技术。客户端发送请求到服务器,服务器保持连接打开,直到有新的数据可用时才响应请求,然后客户端重新发送请求以获取下一次的更新。

  4. Push API: Push API 是浏览器提供的一种机制,允许服务器向客户端发送推送通知,即使网页应用处于后台或关闭状态。

  5. Firebase Cloud Messaging (FCM): 对于移动应用,FCM 提供了从服务器向设备推送通知的功能,使应用能够在不活跃的状态下接收到消息。

  6. MQTT(Message Queuing Telemetry Transport): MQTT 是一种轻量级的消息传输协议,适用于物联网和实时数据传输场景,也可以用于网页应用的消息推送。

这些方式各有优劣,具体的选择取决于您的应用需求和技术栈。请根据您的情况选择最适合的方法来实现服务器向客户端的主动推送。如果您需要更详细的解释或帮助,请随时提问。

from fe-interview.

lili-0923 avatar lili-0923 commented on May 5, 2024

轮询 WebSocket

from fe-interview.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.