Drogon是基于C++17的高性能Web框架,依赖epoll/kqueue实现异步I/O。首先安装OpenSSL、Boost等依赖,通过git克隆并编译Drogon;接着创建main.cc文件,使用drogon::app()设置监听端口8080,注册根路径GET路由返回"Hello from Drogon!";配合CMakeLists.txt配置C++17标准,find_package查找Drogon,构建可执行文件后运行服务;再通过定义HttpController派生类ApiCtrl,使用METHOD_LIST_BEGIN宏添加/time路径处理函数,返回包含当前时间的JSON响应;最终可通过http://localhost:8080访问。关键点包括正确调用callback防止客户端挂起,以及利用CMake管理项目依赖。

使用C++开发Web应用时,Drogon是一个非常高效且现代的选择。它基于C++17和异步I/O(通过epoll或kqueue),提供了简洁的接口来构建高性能Web服务。下面介绍如何快速入门Drogon框架,搭建一个基础Web应用。
安装Drogon框架
Drogon依赖于一些第三方库,如OpenSSL、Boost、CMake等。在Ubuntu系统上可以通过以下命令安装依赖:
- sudo apt-get update
- sudo apt-get install build-essential cmake libssl-dev uuid-dev zlib1g-dev libboost-all-dev
接着克隆并编译Drogon:
- git clone https://github.com/an-tao/drogon
- cd drogon && mkdir build && cd build
- cmake ..
- make && sudo make install
这样就完成了Drogon的全局安装。也可以使用vcpkg或conan进行管理,适合项目隔离场景。
立即学习“C++免费学习笔记(深入)”;
创建第一个HTTP服务
新建一个C++文件,例如main.cc,编写最简单的Web服务器:
#includeint main() { // 设置监听地址和端口 drogon::app().getListener("0.0.0.0", 8080); // 定义根路径的处理函数 drogon::app().registerHandler( "/", [](const drogon::HttpRequestPtr& req, std::function & callback) { auto resp = drogon::HttpResponse::newHttpResponse(); resp->setBody("Hello from Drogon!"); resp->setStatusCode(drogon::k200OK); callback(resp); }, {drogon::Get} ); // 启动事件循环 drogon::app().run(); return 0; }
这个例子注册了一个GET路由/,返回纯文本响应。
使用CMake构建项目
创建CMakeLists.txt文件:
cmake_minimum_required(VERSION 3.5) project(my_web_app) set(CMAKE_CXX_STANDARD 17) find_package(drogon REQUIRED) add_executable(app main.cc) target_link_libraries(app drogon)
然后编译运行:
- mkdir build && cd build
- cmake ..
- make
- ./app
访问http://localhost:8080即可看到输出内容。
添加控制器和JSON支持
Drogon支持MVC模式,可以将逻辑分离到控制器中。创建一个简单的API控制器:
class ApiCtrl : public drogon::HttpController{ public: METHOD_LIST_BEGIN ADD_METHOD_TO(ApiCtrl::getTime, "/time", Get); METHOD_LIST_END void getTime(const drogon::HttpRequestPtr& req, std::function & callback) { Json::Value json; json["time"] = static_cast (time(nullptr)); auto resp = drogon::HttpResponse::newHttpJsonResponse(json); callback(resp); } };
记得在CMakeLists.txt中确保能正确找到头文件,并链接库。控制器会自动注册路由。
基本上就这些。Drogon还支持数据库连接(MySQL、PostgreSQL)、中间件、模板渲染等功能,适合构建复杂Web后端。初学者可以从简单路由入手,逐步掌握异步处理和非阻塞IO模型。关键是理解其回调机制和生命周期管理。不复杂但容易忽略的是:别忘了调用callback(),否则客户端会一直等待。











