Name | Modified | Size | Downloads / Week |
---|---|---|---|
simplewebsocketservercpp-1.2.1.tar.gz | 2015-11-02 | 16.0 kB | |
simplewebsocketservercpp-1.2.tar.gz | 2015-09-08 | 15.2 kB | |
README.md | 2015-09-08 | 1.8 kB | |
simplewebsocketservercpp-1.1.2.tar.gz | 2015-01-30 | 13.8 kB | |
simplewebsocketservercpp-1.1.1.tar.gz | 2014-11-01 | 12.9 kB | |
simplewebsocketservercpp-1.1.tar.gz | 2014-08-14 | 12.5 kB | |
simplewebsocketservercpp-1.04.tar.gz | 2014-08-06 | 8.8 kB | |
simplewebsocketservercpp-1.03.tar.gz | 2014-08-05 | 8.2 kB | |
simplewebsocketservercpp-1.02.tar.gz | 2014-08-02 | 6.9 kB | |
Totals: 9 Items | 96.2 kB | 0 |
Simple-WebSocket-Server
A very simple, fast, multithreaded, platform independent WebSocket (WS) and WebSocket Secure (WSS) server and client library implemented using C++11, Boost.Asio and OpenSSL. Created to be an easy way to make WebSocket endpoints in C++.
See also https://github.com/eidheim/Simple-Web-Server for an easy way to make REST resources available from C++ applications.
Features
- RFC 6455 mostly supported: text/binary frames, ping-pong, connection close with status and reason.
- Thread pool
- Platform independent
- WebSocket Secure support
- Timeouts, if any of SocketServer::timeout_request and SocketServer::timeout_idle are >0 (default: SocketServer::timeout_request=5 seconds, and SocketServer::timeout_idle=0 seconds; no timeout on idle connections)
- Simple way to add WebSocket endpoints using regex for path, and anonymous functions
- An easy to use WebSocket and WebSocket Secure client library
- C++ bindings to the following OpenSSL methods: Base64, MD5, SHA1, SHA256 and SHA512 (found in crypto.hpp)
TODO
- Data from client is currently moved to a separate stream while doing masking. This should happen in the stream instead using a custom stream buffer.
Usage
See ws_examples.cpp or wss_examples.cpp for example usage.
Dependencies
- Boost C++ libraries
- OpenSSL libraries
Compile
Compile with a C++11 compiler supporting regex (for instance g++ 4.9):
cmake .
make
Run server and client examples
WS
./ws_examples
WSS
Before running the WSS-examples, an RSA private key (server.key) and an SSL certificate (server.crt) must be created. Follow, for instance, the instructions given here (for a self-signed certificate): http://www.akadia.com/services/ssh_test_certificate.html
Then:
./wss_examples