【C++/Drogon框架】一、Drogon的安装和开始

本文介绍了Drogon,一个C++的Http应用框架,详细步骤包括安装准备、使用vcpkg安装Drogon及drogon_ctl工具,以及创建并运行第一个Drogon项目的教程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是Drogon

Drogon是一个基于C++17/20的Http应用框架,使用Drogon可以方便的使用C++构建各种类型的Web应用服务端程序。它的名字来自于《权力的游戏》中的一条叫做卓耿的龙。

github: drogonframework/drogon

文档: drogonframework/drogon Wiki

这是一个跨平台的框架,支持Linux、Windows、macOS等多种系统,与Java中的Spring框架类似,它有着解耦、AOP、支持http和websocket等特征,同时,它也保持着C++的特点,比如支持高并发、高性能的网络IO,还有其他的特点都在官方文档中有所描述,可以点进上面的链接查看。

还有值得一提的是它提供了一个轻量的命令行工具drogon_ctl,能够帮忙简化各种类的创建和视图代码的生成过程。

安装Drogon

1、安装准备

  • CMake构建工具
  • git工具
  • Visual Studio
  • vcpkg

2、开始安装

  • 输入vcpkg指令安装:vcpkhg install drogon 或者 vcpkg install drogon:x64-windows(64位的)
  • 安装drogon_ctl:vcpkg install drogon[ctl] 或者 vcpkg install drogon[ctl]:x64-windows(64位的)
  • 添加drogon_ctl到系统环境变量,需要添加以下路径
    • $你的vcpkg安装目录$\installed\x64-windows\tools\drogon
    • $你的vcpkg安装目录$\installed\x64-windows\bin
    • $你的vcpkg安装目录$\installed\x64-windows\lib
    • $你的vcpkg安装目录$\installed\x64-windows\include
  • 重新启动命令行,输入drogon_ctl验证是否添加成功

第一个Drogon项目

1、创建工程

使用drogon_ctl可以快捷的创建一个Drogon项目,在命令行进入项目保存的目录,输入:

drogon_ctl create project drogon_project

运行完可以看到生成了很多文件,这些文件中CMakeLists.txt是工程的cmake配置文件,build文件夹是工程的构建文件夹,至于其他的文件夹有什么用,我们之后再进行介绍。

2、Hello Drogon!

接下来让我们看一下main.cc文件:

#include <drogon/HttpAppFramework.h>
int main() {
    //Set HTTP listener address and port
    drogon::app().addListener("0.0.0.0",80);
    //Load config file
    //drogon::app().loadConfigFile("../config.json");
    //Run HTTP framework,the method will block in the internal event loop
    drogon::app().run();
    return 0;
}

可以看到能修改HTTP监听的地址和端口,我们将其修改为"127.0.0.1", 8080,端口只要是没有被占用的都可以

然后我们使用CMake构建项目,在命令行执行

  • cd build
  • cmake ..

执行完这两行命令后,这时候我们能够发现build文件夹下出现了Visual Studio的.sln解决方案文件

然后我们进入controllers目录,输入:

  • drogon_ctl create controller TestController

可以看见controller目录下多出来一个头文件和一个对应的源文件,再进入build里cmake一下,这时候打开.sln进入Visual Studio界面,可以看到读取到了源文件,头文件这时候可能会被包含在外部依赖项中,找到右键将其包括在项目中即可。顺便可以新建一个筛选器controller,将TestController文件移到里面。
在这里插入图片描述

接着让我们来修改一下TestController.h

#pragma once

#include <drogon/HttpSimpleController.h>

using namespace drogon;

class TestController : public drogon::HttpSimpleController<TestController>
{
  public:
    void asyncHandleHttpRequest(const HttpRequestPtr& req, std::function<void (const HttpResponsePtr &)> &&callback) override;
    PATH_LIST_BEGIN
    // list path definitions here;
    // PATH_ADD("/path", "filter1", "filter2", HttpMethod1, HttpMethod2...);
    // 添加路径映射
    PATH_ADD("/", Get);
    PATH_ADD("/test", Get);
    PATH_LIST_END
};

TestController.cc

#include "TestController.h"

void TestController::asyncHandleHttpRequest(const HttpRequestPtr& req, std::function<void (const HttpResponsePtr &)> &&callback)
{
    // write your application logic here
    // 创建Http响应
    auto resp = HttpResponse::newHttpResponse();
    // 设置状态码为200
    resp->setStatusCode(k200OK);
    // 设置contentType
    resp->setContentTypeCode(CT_TEXT_HTML);
    // 设置响应体
    resp->setBody("Hello Drogon!");
    // 调用回调函数
    callback(resp);
}

接下来就可以启动我们第一个Drogon项目了,如果Debug模式下报错的话,可以进入项目-属性-C/C+±代码生成-运行库,将其修改为MTMD,推测可能是Drogon的第三方库不是Debug模式编译的。

然后在浏览器输入localhost:8080 或者 localhost:8080/test 就能看见输出结果了!

在这里插入图片描述

基于C ++ 14/17的HTTP应用程序框架drogonDrogon可用于使用C ++轻松构建各种类型的Web应用程序服务器程序。 Drogon个跨平台框架,它支持Linux,macOS,FreeBSDWindows。其主要特点如下: *使用基于epoll的非阻塞I / O网络库(macOS / FreeBSD下的kqueue)提供高并发,高性能的网络IO,请访问[TFB测试结果](https://www.techempower。 com / benchmarks /#section = data-r19&hw = ph&test = composite)以获取更多详细信息; *提供完全异步的编程模式; *支持Http1.0 / 1.1(服务器端客户端); *基于模板,实现了种简单的反射机制,以完全解耦主程序框架,控制器视图。 *支持cookie内置会话; *支持后端渲染,控制器将数据生成到视图以生成Html页面。视图由CSP模板文件描述,C ++代码通过CSP标记嵌入到HTML页面中。 drogon命令行工具会自动生成C ++代码文件进行编译; *支持视图页面动态加载(运行时动态编译加载); *提供从路径到控制器处理程序的便捷灵活的路由解决方案; *支持过滤器链,以方便在处理HTTP请求之前执行统的逻辑(例如登录验证,Http方法约束验证等); *支持https(基于OpenSSL); *支持WebSocket(服务器端客户端); *支持JSON格式的请求响应,对Restful API应用程序开发非常友好; *支持文件下载上传; *支持gzip,brotli压缩传输; *支持流水线; *提供轻量级的命令行工具drogon_ctl,以简化Drogon中各种类的创建以及视图代码的生成; *支持基于非阻塞I / O的异步读写数据库(PostgreSQLMySQL(MariaDB)数据库); *支持基于线程池的异步读写sqlite3数据库; *支持ARM体系结构; *提供方便的轻量级ORM实现,支持常规的对象到数据库双向映射; *支持可在加载时由配置文件安装的插件; *通过内置连接点支持AOP。
Drogon个基于C++14/17的Http应用框架,使用Drogon可以方便的使用C++构建各种类型的Web应用服务端程序。 本版本库是github上Drogon工程的镜像库。Drogon是作者非常喜欢的美剧《权力的游戏》中的条龙的名字(汉译作卓耿),龙有关但并不是dragon的误写,为了不至于引起不必要的误会这里说明下。 Drogon个跨平台框架,它支持Linux,也支持macOS、FreeBSD,Windows。它的主要特点如下: 1、网络层使用基于epoll(macOS/FreeBSD下是kqueue)的非阻塞IO框架,提供高并发、高性能的网络IO。详细请见TFB Tests Results; 2、全异步编程模式; 3、支持Http1.0/1.1(server端client端); 4、基于template实现了简单的反射机制,使主程序框架、控制器(controller)视图(view)完全解耦; 5、支持cookies内建的session; 6、支持后端渲染,把控制器生成的数据交给视图生成Html页面,视图由CSP模板文件描述,通过CSP标签把C++代码嵌入到Html页面,由drogon的命令行工具在编译阶段自动生成C++代码并编译; 7、支持运行期的视图页面动态加载(动态编译加载so文件); 8、非常方便灵活的路径(path)到控制器处理函数(handler)的映射方案; 9、支持过滤器(filter)链,方便在控制器之前执行统的逻辑(如登录验证、Http Method约束验证等); 10、支持https(基于OpenSSL实现); 11、支持websocket(server端client端); 12、支持Json格式请求应答, 对Restful API应用开发非常友好; 13、支持文件下载上传,支持sendfile系统调用; 14、支持gzip/brotli压缩传输; 15、支持pipelining; 16、提供个轻量的命令行工具drogon_ctl,帮助简化各种类的创建视图代码的生成过程; 17、基于非阻塞IO实现的异步数据库读写,目前支持PostgreSQLMySQL(MariaDB)数据库; 18、基于线程池实现sqlite3数据库的异步读写,提供与上文数据库相同的接口; 19、支持ARM架构; 20、方便的轻量级ORM实现,支持常规的对象到数据库的双向映射操作; 21、支持插件,可通过配置文件在加载期动态拆装; 22、支持内建插入点的AOP
### 安装配置 Drogon 框架 #### 准备工作 为了在 Windows 上成功安装并配置 Drogon C++ HTTP 框架,需先确认已安装 Visual Studio CMake 工具。Visual Studio 应至少包含 C++ 开发工具包。 #### 下载与编译 Drogon 可以通过 Git 克隆官方仓库来获取最新版本的源码: ```bash git clone --recursive https://github.com/drogonframework/drogon.git cd drogon mkdir build && cd build cmake .. cmake --build . --config Release --target install ``` 上述命令会下载项目及其依赖项,并利用 CMake 构建系统完成编译过程[^1]。 #### 配置开发环境 对于集成开发环境的选择,在此推荐使用 Visual Studio Code (VSCode),因其轻量级且拥有丰富的插件支持。安装好 VSCode 后还需额外安装适用于 C/C++ 的扩展以及 MinGW 或者 MSYS2 来提供 Unix-like shell 环境以便于后续操作。 #### 创建新工程 新建个文件夹作为项目的根目录,初始化为 git 仓库(可选),接着创建 `CMakeLists.txt` 文件用于定义构建规则: ```cmake project(MyDrogonApp) find_package(Drogon REQUIRED CONFIG) add_executable(${PROJECT_NAME} src/main.cpp) target_link_libraries(${PROJECT_NAME} PRIVATE Drogon::Drogon) ``` 同时建立 `src` 子文件夹放置应用程序入口文件 `main.cpp` : ```cpp #include <drogon/drogon.h> using namespace drogon; int main() { app().loadConfigFile("../app.config.json"); app().run(); } ``` 这里调用了 `loadConfigFile()` 方法加载外部 JSON 形式的配置文件以简化内部逻辑[^4]。 #### 编写配置文件 根据实际需求编辑位于项目根路径下的 `app.config.json` ,指定监听端口、日志级别等参数: ```json { "listenerPort": 9000, "logLevel": "info", "threadNum": 4 } ``` 以上即完成了基本的应用程序框架搭建。 #### 进步优化 如果希望进步提升性能或实现特定功能,则可能涉及到更多高级选项调整,比如启用 HTTPS 支持就需要引入 OpenSSL 库;而要处理数据库交互则要考虑加入 SQL 数据库驱动器的支持[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值