2018-05-22 23:15:08 +02:00
|
|
|
---
|
|
|
|
title: Websockets
|
2020-09-12 17:21:54 +02:00
|
|
|
menu: docs_protocols
|
2018-05-22 23:15:08 +02:00
|
|
|
weight: 240
|
|
|
|
---
|
|
|
|
|
2019-06-26 18:55:12 +02:00
|
|
|
Actix-web supports WebSockets with the `actix-web-actors` crate. It is possible to convert a
|
|
|
|
request's `Payload` to a stream of [*ws::Message*][message] with a [*web::Payload*][payload]
|
|
|
|
and then use stream combinators to handle actual messages, but it is simpler to handle
|
|
|
|
websocket communications with an http actor.
|
2018-05-22 23:15:08 +02:00
|
|
|
|
|
|
|
The following is an example of a simple websocket echo server:
|
|
|
|
|
2019-06-18 00:07:57 +02:00
|
|
|
{{< include-example example="websockets" file="main.rs" section="websockets" >}}
|
2018-05-22 23:15:08 +02:00
|
|
|
|
2019-06-25 05:36:32 +02:00
|
|
|
> A simple websocket echo server example is available in the [examples directory][examples].
|
2018-05-22 23:15:08 +02:00
|
|
|
|
2020-09-12 17:21:54 +02:00
|
|
|
> An example chat server with the ability to chat over a websocket or TCP connection
|
2019-06-25 05:36:32 +02:00
|
|
|
> is available in [websocket-chat directory][chat]
|
|
|
|
|
2019-12-28 20:16:54 +01:00
|
|
|
[message]: https://docs.rs/actix-web-actors/2/actix_web_actors/ws/enum.Message.html
|
2020-09-12 17:21:54 +02:00
|
|
|
[payload]: https://docs.rs/actix-web/3/actix_web/web/struct.Payload.html
|
2021-02-26 19:48:27 +01:00
|
|
|
[examples]: https://github.com/actix/examples/tree/master/websockets/websocket
|
|
|
|
[chat]: https://github.com/actix/examples/tree/master/websockets/chat
|