Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/snapview/tungstenite-rs
Lightweight stream-based WebSocket implementation for Rust.
https://github.com/snapview/tungstenite-rs
rust websockets
Last synced: 2 days ago
JSON representation
Lightweight stream-based WebSocket implementation for Rust.
- Host: GitHub
- URL: https://github.com/snapview/tungstenite-rs
- Owner: snapview
- License: apache-2.0
- Created: 2017-03-17T15:38:17.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2025-02-07T14:15:19.000Z (13 days ago)
- Last Synced: 2025-02-16T14:12:25.246Z (4 days ago)
- Topics: rust, websockets
- Language: Rust
- Size: 730 KB
- Stars: 2,015
- Watchers: 24
- Forks: 225
- Open Issues: 31
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE-APACHE
Awesome Lists containing this project
- awesome-rust-cn - snapview/tungstenite-rs - based WebSocket implementation for Rust. (Libraries / Web programming)
- awesome-rust - snapview/tungstenite-rs - based WebSocket implementation for Rust. (Libraries / Web programming)
- awesome-rust - snapview/tungstenite-rs - based WebSocket implementation. (Libraries / Web programming)
- awesome-rust-cn - snapview/tungstenite-rs
- awesome-edge - Tungstenite WS - Lightweight stream-based WebSocket implementation for Rust. (_Table of Contents_ / Websockets)
- awesome-rust-zh - snapview/tungstenite-rs - 轻量级的基于流的 WebSocket 实现。 (库 / 网页编程)
README
# Tungstenite
Lightweight stream-based WebSocket implementation for [Rust](https://www.rust-lang.org/).
```rust
use std::net::TcpListener;
use std::thread::spawn;
use tungstenite::accept;/// A WebSocket echo server
fn main () {
let server = TcpListener::bind("127.0.0.1:9001").unwrap();
for stream in server.incoming() {
spawn (move || {
let mut websocket = accept(stream.unwrap()).unwrap();
loop {
let msg = websocket.read().unwrap();// We do not want to send back ping/pong messages.
if msg.is_binary() || msg.is_text() {
websocket.send(msg).unwrap();
}
}
});
}
}
```Take a look at the examples section to see how to write a simple client/server.
**NOTE:** `tungstenite-rs` is more like a barebone to build reliable modern networking applications
using WebSockets. If you're looking for a modern production-ready "batteries included" WebSocket
library that allows you to efficiently use non-blocking sockets and do "full-duplex" communication,
take a look at [`tokio-tungstenite`](https://github.com/snapview/tokio-tungstenite).[](./LICENSE-MIT)
[](./LICENSE-APACHE)
[](https://crates.io/crates/tungstenite)
[](https://github.com/snapview/tungstenite-rs/actions)[Documentation](https://docs.rs/tungstenite)
Introduction
------------
This library provides an implementation of WebSockets,
[RFC6455](https://tools.ietf.org/html/rfc6455). It allows for both synchronous (like TcpStream)
and asynchronous usage and is easy to integrate into any third-party event loops including
[MIO](https://github.com/tokio-rs/mio). The API design abstracts away all the internals of the
WebSocket protocol but still makes them accessible for those who wants full control over the
network.Why Tungstenite?
----------------It's formerly WS2, the 2nd implementation of WS. WS2 is the chemical formula of
tungsten disulfide, the tungstenite mineral.Features
--------Tungstenite provides a complete implementation of the WebSocket specification.
TLS is supported on all platforms using `native-tls` or `rustls`. The following
features are available:* `native-tls`
* `native-tls-vendored`
* `rustls-tls-native-roots`
* `rustls-tls-webpki-roots`Choose the one that is appropriate for your needs.
By default **no TLS feature is activated**, so make sure you use one of the TLS features,
otherwise you won't be able to communicate with the TLS endpoints.There is no support for permessage-deflate at the moment, but the PRs are welcome :wink:
Testing
-------Tungstenite is thoroughly tested and passes the [Autobahn Test Suite](https://github.com/crossbario/autobahn-testsuite) for
WebSockets. It is also covered by internal unit tests as well as possible.Contributing
------------Please report bugs and make feature requests [here](https://github.com/snapview/tungstenite-rs/issues).