当前位置:   article > 正文

GitHub 开源推荐 | 一个轻量级、高性能的 C++ Web 框架_轻量github

轻量github

说起 Web 开发,大多数人会想到 Java、Python、Golang ... 因为它们的主流 Web 框架有很多,Java 有非常知名的 Spring 全家桶,Python 有大而全的 Django、小而精的 Flask、高性能的 Tornado,Golang 也有快速灵活的 Gin、Echo 等框架。

相比之下,C/C++ 阵营则逊色不少。有一个名为 Oat++ 的很不错,轻量、跨平台、高性能、完全零依赖,非常值得学习!

1

Oat++ 介绍

要深入了解 Oat++,离不开这几个网址:

  • Oat++ 主页:https://oatpp.io

  • Oat++ 文档:https://oatpp.io/docs/start

  • GitHub 地址:https://github.com/oatpp/oatpp

其主要特性有:

  • 随处运行

    Oat++ 没有任何依赖性,可以很容易地移植到各种支持的平台上(Linux、MacOS、Windows)。

  • 构建健壮的api

    使用 Oat++ Simple-API,构建灵活而健壮的 API 既简单又有趣。

  • 处理 500 万个连接

    使用 Oat++ Async-API,可以在单个服务器上处理超过 500 万个并发连接。

  • 访问数据库

    Oat++ ORM 提供了一种简单而统一的方式来访问数据库

  • 保持代码一致

    Oat++ 在整个代码库中依靠对象映射来确保 API 和数据模型的一致性

  • 生成 API 文档

    使用 Swagger-UI 和 OpenAPI 3.0.0 自动记录 endpoints

最吸引我的是 HTTP/HTTPS、文件上传/下载、以及强大的  Swagger API 功能。
2

编译 Oat++

进入 Oat++ 的 GitHub 页面,你会发现 Star 多达 4K+,贡献者有 30 多个,且最近几天还有代码提交,所以不用担心热度和活跃度,这个框架一直有人在积极地维护。

环境要求

Oat++ 的编译过程很简单,只需要有基本的开发环境就行了:

  • Git

  • 编译器支持的 C++ 版本 >= 11

  • Make

  • CMake 版本 >= 3.1

如果没有的话,按照下述步骤安装,以 Ubuntu 为例:

  1. $ sudo apt install git
  2. $ sudo apt install cmake
  3. $ sudo apt install build-essential

编译安装

下载 Oat++ 源码:

$ git clone https://github.com/oatpp/oatpp.git

随后,执行编译安装四部曲:

  1. $ cd oatpp/
  2. $ mkdir build && cd build
  3. $ cmake ..
  4. $ sudo make && sudo make install

3

示例程序

为了演示 Oat++,我们从最简单的“Hello, World!”开始!

创建一个 CMake 项目,CMakeLists.txt 配置如下:

  1. cmake_minimum_required(VERSION 3.1)
  2. project(helloworld)
  3. set(CMAKE_CXX_STANDARD 11)
  4. set(SOURCE_FILES main.cpp handler.h)
  5. # 查找 oatpp 依赖
  6. find_package(oatpp REQUIRED)
  7. add_executable(${PROJECT_NAME} ${SOURCE_FILES})
  8. # 将目标文件与库文件进行链接
  9. target_link_libraries(${PROJECT_NAME} oatpp::oatpp)

默认情况下,Oat++ 会对客户端请求响应 404,除此之外什么都不做。

若要添加自定义响应,必须实现 HttpRequestHandler:

  1. // handler.h
  2. #ifndef HANDLER_H
  3. #define HANDLER_H
  4. #include "oatpp/web/server/HttpRequestHandler.hpp"
  5. #define O_UNUSED(x) (void)x;
  6. // 自定义请求处理程序
  7. class Handler : public oatpp::web::server::HttpRequestHandler
  8. {
  9. public:
  10.     // 处理传入的请求,并返回响应
  11.     std::shared_ptr<OutgoingResponse> handle(const std::shared_ptr<IncomingRequest>& request) override {
  12.         O_UNUSED(request);
  13.         
  14.         return ResponseFactory::createResponse(Status::CODE_200, "Hello, World!");
  15.     }
  16. };
  17. #endif // HANDLER_H

有了处理程序之后,需要通过 Router 将请求路由到它:

  1. // main.cpp
  2. #include "oatpp/web/server/HttpConnectionHandler.hpp"
  3. #include "oatpp/network/tcp/server/ConnectionProvider.hpp"
  4. #include "oatpp/network/Server.hpp"
  5. #include "handler.h"
  6. void run()
  7. {
  8.     // 为 HTTP 请求创建路由器
  9.     auto router = oatpp::web::server::HttpRouter::createShared();
  10.     // 路由 GET - "/hello" 请求到处理程序
  11.     router->route("GET""/hello", std::make_shared<Handler>());
  12.     // 创建 HTTP 连接处理程序
  13.     auto connectionHandler = oatpp::web::server::HttpConnectionHandler::createShared(router);
  14.     // 创建 TCP 连接提供者
  15.     auto connectionProvider = oatpp::network::tcp::server::ConnectionProvider::createShared({"localhost"8000, oatpp::network::Address::IP_4});
  16.     // 创建服务器,它接受提供的 TCP 连接并将其传递给 HTTP 连接处理程序
  17.     oatpp::network::Server server(connectionProvider, connectionHandler);
  18.     // 打印服务器端口
  19.     OATPP_LOGI("MyApp""Server running on port %s", connectionProvider->getProperty("port").getData());
  20.     // 运行服务器
  21.     server.run();
  22. }
  23. int main()
  24. {
  25.     // 初始化 oatpp 环境
  26.     oatpp::base::Environment::init();
  27.     // 运行应用
  28.     run();
  29.     // 销毁 oatpp 环境
  30.     oatpp::base::Environment::destroy();
  31.     return 0;
  32. }

4

请求验证

运行程序,在浏览器中访问 http://localhost:8000/hello,就会显示“Hello, World!”信息了:

或者使用 curl 请求 http://127.0.0.1:8000/hello,效果一样:

  1. $ curl http://127.0.0.1:8000/hello
  2. Hello, World!
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/395266
推荐阅读
相关标签
  

闽ICP备14008679号