C++ websocket client/server library

本教程介绍了如何使用WebSocket++库建立WebSocket连接,处理消息发送和接收,以及设置和关闭连接。步骤包括初始化、配置、错误处理、连接管理以及TLS/SecureWebSocket的使用。示例代码展示了从用户输入读取命令,创建WebSocket连接,记录发送和接收的消息,以及在连接关闭时的处理流程。
摘要由CSDN通过智能技术生成

Chapter 1: Initial Setup & Basics

Setting up the basic types, opening and closing connections, sending and receiving messages.

Step 1

A basic program loop that prompts the user for a command and then processes it. In this tutorial we will modify this program to perform tasks and retrieve data from a remote server over a WebSocket connection.

Build

clang++ step1.cpp

Code so far

note A code snapshot for each step is present next to this tutorial file in the git repository.

#include <iostream>

#include <string>

int main() {

bool done = false;

std::string input;

while (!done) {

std::cout << "Enter Command: ";

std::getline(std::cin, input);

if (input == "quit") {

done = true;

} else if (input == "help") {

std::cout

<< "\nCommand List:\n"

<< "help: Display this help text\n"

<< "quit: Exit the program\n"

<< std::endl;

} else {

std::cout << "Unrecognized Command" << std::endl;

}

}

return 0;

}

Step 2

Add WebSocket++ includes and set up an endpoint type.

WebSocket++ includes two major object types. The endpoint and the connection. The endpoint creates and launches new connections and maintains default settings for those connections. Endpoints also manage any shared network resources.

The connection stores information specific to each WebSocket session.

Note: Once a connection is launched, there is no link between the endpoint and the connection. All default settings are copied into the new connection by the endpoint. Changing default settings on an endpoint will only affect future connections.

Connections do not maintain a link back to their associated endpoint. Endpoints do not maintain a list of outstanding connections. If your application needs to iterate over all connections it will need to maintain a list of them itself.

WebSocket++ endpoints are built by combining an endpoint role with an endpoint config. There are two different types of endpoint roles, one each for the client and server roles in a WebSocket session. This is a client tutorial so we will use the client role websocketpp::client which is provided by the <websocketpp/client.hpp> header.

Terminology: Endpoint Config

WebSocket++ endpoints have a group of settings that may be configured at compile time via the config template parameter. A config is a struct that contains types and static constants that are used to produce an endpoint with specific properties. Depending on which config is being used the endpoint will have different methods available and may have additional third party dependencies.

The endpoint role takes a template parameter called config that is used to configure the behavior of endpoint at compile time. For this example we are going to use a default config provided by the library called asio_client, provided by <websocketpp/config/asio_no_tls_client.hpp>. This is a client config that uses boost::asio to provide network transport and does not support TLS based security. Later on we will discuss how to introduce TLS based security into a WebSocket++ application, more about the other stock configs, and how to build your own custom configs.

Combine a config with an endpoint role to produce a fully configured endpoint. This type will be used frequently so I would recommend a typedef here.

typedef websocketpp::client<websocketpp::config::asio_client> client

Build

Adding WebSocket++ has added a few dependencies to our program that must be addressed in the build system. Firstly, the WebSocket++ and Boost library headers must be in the include search path of your build system. How exactly this is done depends on where you have the WebSocket++ headers installed and what build system you are using.

In addition to the new headers, boost::asio depends on the boost_system shared library. This will need to be added (either as a static or dynamic) to the linker. Refer to your build environment documentation for instructions on linking to shared libraries.

clang++ step2.cpp -lboost_system

Code so far

#include <websocketpp/config/asio_no_tls_client.hpp>

#include <websocketpp/client.hpp>

#include <iostream>

#include <string>

typedef websocketpp::client<websocketpp::config::asio_client> client;

int main() {

bool done = false;

std::string input;

while (!done) {

std::cout << "Enter Command: ";

std::getline(std::cin, input);

if (input == "quit") {

done = true;

} else if (input == "help") {

std::cout

<< "\nCommand List:\n"

<< "help: Display this help text\n"

<< "quit: Exit the program\n"

<< std::endl;

} else {

std::cout << "Unrecognized Command" << std::endl;

}

}

return 0;

}

Step 3

Create endpoint wrapper object that handles initialization and setting up the background thread.

In order to process user input while network processing occurs in the background we are going to use a separate thread for the WebSocket++ processing loop. This leaves the main thread free to process foreground user input. In order to enable simple RAII style resource management for our thread and endpoint we will use a wrapper object that configures them both in its constructor.

Terminology: websocketpp::lib namespace

WebSocket++ is designed to be used with a C++11 standard library. As this is not universally available in popular build systems the Boost libraries may be used as polyfills for the C++11 standard library in C++98 build environments. The websocketpp::lib namespace is used by the library and its associated examples to abstract away the distinctions between the two. websocketpp::lib::shared_ptr will evaluate to std::shared_ptr in a C++11 environment and boost::shared_ptr otherwise.

This tutorial uses the websocketpp::lib wrappers because it doesn't know what the build environment of the reader is. For your applications, unless you are interested in similar portability, are free to use the boost or std versions of these types directly.

>[TODO: link to more information about websocketpp::lib namespace and C++11 setup]

Within the websocket_endpoint constructor several things happen:

First, we set the endpoint logging behavior to silent by clearing all of the access and error logging channels. [TODO: link to more information about logging]

m_endpoint.clear_access_channels(websocketpp::log::alevel::all);

m_endpoint.clear_error_channels(websocketpp::log::elevel::all);

Next, we initialize the transport system underlying the endpoint and set it to perpetual mode. In perpetual mode the endpoint's processing loop will not exit automatically when it has no connections. This is important because we want this endpoint to remain active while our application is running and process requests for new WebSocket connections on demand as we need them. Both of these methods are specific to the asio transport. They will not be necessary or present in endpoints that use a non-asio config.

m_endpoint.init_asio();

m_endpoint.start_perpetual();

Finally, we launch a thread to run the run method of our client endpoint. While the endpoint is running it will process connection tasks (read and deliver incoming messages, frame and send outgoing messages, etc). Because it is running in perpetual mode, when there are no connections active it will wait for a new connection.

m_thread.reset(new websocketpp::lib::thread(&client::run, &m_endpoint));

Build

Now that our client endpoint template is actually instantiated a few more linker dependencies will show up. In particular, WebSocket clients require a cryptographically secure random number generator. WebSocket++ is able to use either boost_random or the C++11 standard library <random> for this purpose. Because this example also uses threads, if we do not have C++11 std::thread available we will need to include boost_thread.

Clang (C++98 & boost)

clang++ step3.cpp -lboost_system -lboost_random -lboost_thread

Clang (C++11)

clang++ -std=c++0x -stdlib=libc++ step3.cpp -lboost_system -D_WEBSOCKETPP_CPP11_STL_

G++ (C++98 & Boost)

g++ step3.cpp -lboost_system -lboost_random -lboost_thread

G++ v4.6+ (C++11)

g++ -std=c++0x step3.cpp -lboost_system -D_WEBSOCKETPP_CPP11_STL_

Code so far

#include <websocketpp/config/asio_no_tls_client.hpp>

#include <websocketpp/client.hpp>

#include <websocketpp/common/thread.hpp>

#include <websocketpp/common/memory.hpp>

#include <iostream>

#include <string>

typedef websocketpp::client<websocketpp::config::asio_client> client;

class

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值