用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<br>cd drogon && mkdir build && cd build<br>cmake .. -DCMAKE_BUILD_TYPE=Release<br>make -j$(nproc) && sudo make install
- 验证是否成功:
drogon_ctl version能打出版本号就 OK
写一个最简 HTTP 接口
新建项目目录,用 drogon_ctl create project hello_world 生成骨架;进目录后,在 controllers/ 下加一个处理器:
// controllers/HelloController.h
#pragma once
#include <drogon/HttpController.h>
using namespace drogon;
<p>class HelloController : public HttpController<HelloController>
{
public:
METHOD_LIST_BEGIN
ADD_METHOD_TO(HelloController::handleGet, "/hello", Get);
METHOD_LIST_END</p><pre class="brush:php;toolbar:false;">void handleGet(const HttpRequestPtr& req, std::function<void(const HttpResponsePtr&)>&& callback) const;};
// controllers/HelloController.cc
#include "HelloController.h"
#include <drogon/HttpResponse.h>
<p>void HelloController::handleGet(const HttpRequestPtr& req,
std::function<void(const HttpResponsePtr&)>&& callback) const
{
auto resp = HttpResponse::newHttpResponse();
resp->setBody("Hello from Drogon!");
callback(resp);
}
</p>别忘了在 main.cc 的 app().registerController<hellocontroller>();</hellocontroller> 注册它。
立即学习“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");<br>f.then([callback](const Result& r) { ... });
不复杂但容易忽略:路由注册顺序影响匹配、JSON 字段名默认按 C++ 成员名转 snake_case、生产环境务必关掉 debug 模式并用 HTTPS。起步就这四块,跑通再扩功能。











