使用 Poco C++ 库构建轻量级 HTTP 服务器

在现代 C++ 后端开发中,如果你需要构建一个轻量、高性能、可嵌入式的 HTTP 服务,而不愿引入重量级框架如 Boost.Beast 或 cpp-httplib,那么 Poco C++ Libraries 提供了一个优雅的解决方案。Poco 是一套广泛使用的 C++ 框架,涵盖网络、线程、文件系统、JSON/XML 等模块。

本篇文章将手把手教你如何使用 Poco 构建一个基础的 HTTP Server,并扩展为一个具备实际用途的请求处理器。


✨ 为什么选择 Poco?

  • 易于集成,无外部依赖(仅需 CMake + 编译 Poco)

  • 支持多线程、高并发

  • 内置 HTTPServer、WebSocket、REST 支持

  • 类似 Java Servlet 模型:请求/响应 + 工厂 + Handler

    cpp 复制代码
    my_http_server/
    ├── CMakeLists.txt
    ├── MyHttpApp.h
    ├── MyHttpApp.cpp
    ├── RequestHandlerFactory.h
    ├── RequestHandlerFactory.cpp
    └── main.cpp

    项目结构

    cpp 复制代码
    // RequestHandlerFactory.h
    #pragma once
    #include <Poco/Net/HTTPRequestHandlerFactory.h>
    #include <Poco/Net/HTTPRequestHandler.h>
    #include <Poco/Net/HTTPServerRequest.h>
    #include <Poco/Net/HTTPServerResponse.h>
    
    class RequestHandler : public Poco::Net::HTTPRequestHandler {
    public:
        void handleRequest(Poco::Net::HTTPServerRequest& request,
                           Poco::Net::HTTPServerResponse& response) override;
    };
    
    class RequestHandlerFactory : public Poco::Net::HTTPRequestHandlerFactory {
    public:
        Poco::Net::HTTPRequestHandler* createRequestHandler(const Poco::Net::HTTPServerRequest&) override;
    };
    cpp 复制代码
    // RequestHandlerFactory.cpp
    #include "RequestHandlerFactory.h"
    #include <iostream>
    
    void RequestHandler::handleRequest(Poco::Net::HTTPServerRequest& request,
                                       Poco::Net::HTTPServerResponse& response) {
        response.setStatus(Poco::Net::HTTPResponse::HTTP_OK);
        response.setContentType("text/plain");
    
        std::ostream& ostr = response.send();
        ostr << "Hello from Poco ServerApplication HTTP Server!\n";
    }
    
    Poco::Net::HTTPRequestHandler* RequestHandlerFactory::createRequestHandler(const Poco::Net::HTTPServerRequest&) {
        return new RequestHandler;
    }
    cpp 复制代码
    #pragma once
    #include <Poco/Util/ServerApplication.h>
    #include <Poco/Net/HTTPServer.h>
    #include <Poco/Net/HTTPServerParams.h>
    #include <Poco/Net/ServerSocket.h>
    
    class MyHttpApp : public Poco::Util::ServerApplication {
    protected:
        int main(const std::vector<std::string>& args) override;
    };
    cpp 复制代码
    #include "MyHttpApp.h"
    #include "RequestHandlerFactory.h"
    #include <iostream>
    
    int MyHttpApp::main(const std::vector<std::string>& args) {
        Poco::UInt16 port = 8080;
        Poco::Net::ServerSocket svs(port);
    
        Poco::Net::HTTPServerParams* params = new Poco::Net::HTTPServerParams;
        params->setMaxQueued(100);
        params->setMaxThreads(8);
    
        Poco::Net::HTTPServer server(new RequestHandlerFactory, svs, params);
        server.start();
        std::cout << "HTTP server started on port " << port << std::endl;
    
        waitForTerminationRequest();  // 等待 Ctrl+C 或 kill 信号
        std::cout << "Shutting down..." << std::endl;
        server.stop();
    
        return Application::EXIT_OK;
    }
    cpp 复制代码
    //main.cpp
    #include "MyHttpApp.h"
    
    int main(int argc, char** argv) {
        MyHttpApp app;
        return app.run(argc, argv);
    }
    cpp 复制代码
    #CMakeLists.txt
    cmake_minimum_required(VERSION 3.10)
    project(MyPocoHttpServer)
    
    find_package(Poco REQUIRED Net Util Foundation)
    
    add_executable(server
        main.cpp
        MyHttpApp.cpp
        RequestHandlerFactory.cpp
    )
    
    target_link_libraries(server
        Poco::Net
        Poco::Util
        Poco::Foundation
    )

    构建和运行

    bash 复制代码
    mkdir build && cd build
    cmake ..
    make
    ./server
相关推荐
Gofarlic_oms14 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
AI+程序员在路上5 小时前
VS Code 完全使用指南:下载、安装、核心功能与 内置AI 编程助手实战
开发语言·人工智能·windows·开源
invicinble5 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
catchadmin5 小时前
使用 PHP TrueAsync 改造 Laravel 协程异步化的可行路径
开发语言·php·laravel
wbs_scy5 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
郑州光合科技余经理7 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
南子北游8 小时前
Python学习(基础语法1)
开发语言·python·学习
张健11564096488 小时前
使用信号量限制并发数量
开发语言·c++
jc06208 小时前
6.1云原生之Docker
c++·docker·云原生