用Drogon做C++ Web开发核心三步:安装框架、编写HTTP处理器、运行服务;它自带异步网络栈、无需Boost、编译快性能高,适合原生C++后端开发。

用 Drogon 做 C++ Web 开发,核心就三步:装好框架、写个 HTTP 处理器、跑起来。它不依赖 Boost(自带异步网络栈),编译快、性能高,适合想用原生 C++ 写后端又不想折腾底层的同学。
安装 Drogon(Linux/macOS 推荐方式)
Drogon 用 CMake 构建,建议从源码编译安装,版本可控、无包管理器兼容问题:
- 先装依赖:git cmake g++ (或 clang++) OpenSSL 开发库(如 libssl-dev)
- 拉代码编译:
git clone https://github.com/an-tao/drogon
cd drogon && mkdir build && cd build
cmake .. -DCMAKE_BUILD_TYPE=Release
make -j$(nproc) && sudo make install - 验证是否成功:
drogon_ctl version能打出版本号就 OK
写一个最简 HTTP 接口
新建项目目录,用 drogon_ctl create project hello_world 生成骨架;进目录后,在 controllers/ 下加一个处理器:
// controllers/HelloController.h #pragma once #includeusing namespace drogon; class HelloController : public HttpController
{ public: METHOD_LIST_BEGIN ADD_METHOD_TO(HelloController::handleGet, "/hello", Get); METHOD_LIST_END void handleGet(const HttpRequestPtr& req, std::function&& callback) const; };
// controllers/HelloController.cc #include "HelloController.h" #includevoid HelloController::handleGet(const HttpRequestPtr& req, std::function
&& callback) const { auto resp = HttpResponse::newHttpResponse(); resp->setBody("Hello from Drogon!"); callback(resp); } 别忘了在
main.cc的app().registerController注册它。(); 立即学习“C++免费学习笔记(深入)”;
编译运行 & 热重载调试
项目根目录执行:
mkdir build && cd build && cmake .. && make编译./hello_world启动,默认监听http://127.0.0.1:8080- 访问
curl http://localhost:8080/hello应返回文本- 开发时推荐开热重载:
drogon_ctl create project -d myapp生成带 dev server 的模板,改代码自动重启接数据库和 JSON API(实用起点)
多数接口要读写数据。Drogon 内置 ORM 支持 PostgreSQL / MySQL / SQLite:
- 在
src/config.json配数据库连接(注意开启"db_clients")- 定义 Model:
drogon_ctl create model User,然后补字段(如DEFINE_FIELD(id, Int64, false))- 写接口返回 JSON:
用Json::Value构造数据,HttpResponse::newHttpJsonResponse(jsonObj)包装返回- 异步查库示例:
auto f = dbClient->execSqlAsyncFuture("SELECT * FROM users");
f.then([callback](const Result& r) { ... });不复杂但容易忽略:路由注册顺序影响匹配、JSON 字段名默认按 C++ 成员名转 snake_case、生产环境务必关掉
debug模式并用 HTTPS。起步就这四块,跑通再扩功能。











