用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 #include using 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" #include void 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。起步就这四块,跑通再扩功能。