webSocket模块组件

对应的头文件

cpp 复制代码
#include <websocketpp/config/asio_no_tls.hpp>
#include <websocketpp/server.hpp>
#include <nlohmann/json.hpp>
#include <boost/asio.hpp>
#include <queue>
#include <functional>
#include <memory>
#include <mutex>

using json = nlohmann::json;
using namespace websocketpp;

namespace asio = boost::asio;
using asio::io_context;

WebSocketServer类的实现

cpp 复制代码
// WebSocket服务器类
class WebSocketServer {
public:
    using server_type = server<config::asio>;
    WebSocketServer(asio::io_context& io_context)
        : m_server(io_context),
          m_io_context(io_context) {}

    void start(uint16_t port);
    void stop();
    void handle_message(server_type::connection_hdl hdl, server_type::message_ptr msg);

private:
    server_type m_server;
    asio::io_context& m_io_context;
};

MessageHandler类的实现:

cpp 复制代码
// 消息处理器类
class MessageHandler {
public:
    static void process_message(const json& message, std::function<void(json)> callback);
};

ConnectionManager类的实现:

cpp 复制代码
// 连接管理器类
class ConnectionManager {
public:
    void on_open(server_type::connection_hdl hdl);
    void on_close(server_type::connection_hdl hdl);

private:
    std::mutex m_mutex;
    std::unordered_map<server_type::connection_hdl, bool> m_connections;
};

TaskQueue类的实现:

cpp 复制代码
// 异步任务队列类
class TaskQueue {
public:
    void enqueue(std::function<void()> task);
    void run();

private:
    std::queue<std::function<void()>> m_queue;
    std::mutex m_mutex;
    std::condition_variable m_condition;
};

类函数的定义

cpp 复制代码
void WebSocketServer::start(uint16_t port) {
    m_server.init_asio();
    m_server.set_access_channels(websocketpp::log::alevel::all);
    m_server.clear_access_channels(websocketpp::log::alevel::frame_payload);
    m_server.listen(port);
    m_server.set_open_handler(std::bind(&ConnectionManager::on_open, &m_connection_manager, std::placeholders::_1));
    m_server.set_close_handler(std::bind(&ConnectionManager::on_close, &m_connection_manager, std::placeholders::_1));
    m_server.set_message_handler(std::bind(&WebSocketServer::handle_message, this, std::placeholders::_1, std::placeholders::_2));
    m_server.start_accept();
    m_io_context.run();
}

void WebSocketServer::stop() {
    m_io_context.stop();
}

void WebSocketServer::handle_message(server_type::connection_hdl hdl, server_type::message_ptr msg) {
    try {
        auto j = json::parse(msg->get_payload());
        MessageHandler::process_message(j, [this, hdl](const json& response) {
            m_server.send(hdl, response.dump(), websocketpp::frame::opcode::text);
        });
    } catch (std::exception& e) {
        // 错误处理
    }
}

void MessageHandler::process_message(const json& message, std::function<void(json)> callback) {
    // 根据消息类型处理消息
    if (message["type"] == "request") {
        // 调用相应的业务逻辑
        // ...

        // 假设我们得到了响应数据
        json response = {{"type", "response"}, {"data", "Hello World!"}};
        callback(response);
    }
}

void ConnectionManager::on_open(server_type::connection_hdl hdl) {
    std::lock_guard<std::mutex> lock(m_mutex);
    m_connections[hdl] = true;
}

void ConnectionManager::on_close(server_type::connection_hdl hdl) {
    std::lock_guard<std::mutex> lock(m_mutex);
    m_connections.erase(hdl);
}

void TaskQueue::enqueue(std::function<void()> task) {
    std::lock_guard<std::mutex> lock(m_mutex);
    m_queue.push(task);
    m_condition.notify_one();
}

void TaskQueue::run() {
    std::unique_lock<std::mutex> lock(m_mutex);
    while (true) {
        if (!m_queue.empty()) {
            auto task = std::move(m_queue.front());
            m_queue.pop();
            lock.unlock();
            task();
            lock.lock();
        } else {
            m_condition.wait(lock);
        }
    }
}
相关推荐
IP管家24 分钟前
企业级IP代理解决方案:负载均衡与API接口集成实践
服务器·网络·数据库·网络协议·tcp/ip·容器·负载均衡
愚润求学31 分钟前
【Linux】进程间通信(一):认识管道
linux·运维·服务器·开发语言·c++·笔记
霸王蟹39 分钟前
React中useState中更新是同步的还是异步的?
前端·javascript·笔记·学习·react.js·前端框架
霸王蟹42 分钟前
React Hooks 必须在组件最顶层调用的原因解析
前端·javascript·笔记·学习·react.js
专注VB编程开发20年1 小时前
asp.net IHttpHandler 对分块传输编码的支持,IIs web服务器后端技术
服务器·前端·asp.net
光不度AoKaNa1 小时前
计算机操作系统概要
linux·运维·服务器
Clownseven1 小时前
[IP地址科普] 服务器公网IP、私网IP、弹性IP是什么?区别与应用场景详解
服务器·网络协议·tcp/ip
爱分享的程序员1 小时前
全栈项目搭建指南:Nuxt.js + Node.js + MongoDB
前端
Easy_Package2 小时前
Linux中的进程
linux·服务器·网络
隐含2 小时前
webpack打包,把png,jpg等文件按照在src目录结构下的存储方式打包出来。解决同一命名的图片资源在打包之后,重复命名的图片就剩下一个图片了。
前端·webpack·node.js