oaptt搭建http服務(wù)的過程詳解
Oat++ 介紹
Oat++ 主頁:https://oatpp.io
Oat++ 文檔:https://oatpp.io/docs/start
GitHub 地址:https://github.com/oatpp/oatpp
編譯 Oat++
環(huán)境要求
Oat++ 的編譯過程很簡單,只需要有基本的開發(fā)環(huán)境就行了:
- Git
- 編譯器支持的 C++ 版本 >= 11
- Make
- CMake 版本 >= 3.1
如果沒有的話,按照下述步驟安裝,以 Ubuntu 為例:
sudo apt install git sudo apt install cmake sudo apt install build-essential
編譯安裝
下載 Oat++ 源碼:
git clone https://github.com/oatpp/oatpp.git
隨后,執(zhí)行編譯安裝四部曲:
cd oatpp/ mkdir build && cd build cmake .. sudo make && sudo make install
hello示例程序
為了演示 Oat++,我們從最簡單的“Hello, World!”開始!
創(chuàng)建一個 CMake 項(xiàng)目,CMakeLists.txt 配置如下:
cmake_minimum_required(VERSION 3.1)
project(helloworld)
set(CMAKE_CXX_STANDARD 11)
set(SOURCE_FILES main.cpp handler.h)
# 查找 oatpp 依賴
find_package(oatpp REQUIRED)
add_executable(${PROJECT_NAME} ${SOURCE_FILES})
# 將目標(biāo)文件與庫文件進(jìn)行鏈接
target_link_libraries(${PROJECT_NAME} oatpp::oatpp)handler.h
// handler.h
#ifndef HANDLER_H
#define HANDLER_H
#include "oatpp/web/server/HttpRequestHandler.hpp"
#define O_UNUSED(x) (void)x;
// 自定義請求處理程序
class Handler : public oatpp::web::server::HttpRequestHandler
{
public:
// 處理傳入的請求,并返回響應(yīng)
std::shared_ptr<OutgoingResponse> handle(const std::shared_ptr<IncomingRequest>& request) override {
O_UNUSED(request);
return ResponseFactory::createResponse(Status::CODE_200, "Hello, World!");
}
};
#endif // HANDLER_H
main.cpp
// main.cpp
#include "oatpp/web/server/HttpConnectionHandler.hpp"
#include "oatpp/network/tcp/server/ConnectionProvider.hpp"
#include "oatpp/network/Server.hpp"
#include "handler.h"
void run()
{
// 為 HTTP 請求創(chuàng)建路由器
auto router = oatpp::web::server::HttpRouter::createShared();
// 路由 GET - "/hello" 請求到處理程序
router->route("GET", "/hello", std::make_shared<Handler>());
// 創(chuàng)建 HTTP 連接處理程序
auto connectionHandler = oatpp::web::server::HttpConnectionHandler::createShared(router);
// 創(chuàng)建 TCP 連接提供者
auto connectionProvider = oatpp::network::tcp::server::ConnectionProvider::createShared({"0.0.0.0", 8080, oatpp::network::Address::IP_4});
// 創(chuàng)建服務(wù)器,它接受提供的 TCP 連接并將其傳遞給 HTTP 連接處理程序
oatpp::network::Server server(connectionProvider, connectionHandler);
// 打印服務(wù)器端口
OATPP_LOGI("MyApp", "Server running on port %s", connectionProvider->getProperty("port").getData());
// 運(yùn)行服務(wù)器
server.run();
}
int main()
// 初始化 oatpp 環(huán)境
oatpp::base::Environment::init();
// 運(yùn)行應(yīng)用
run();
// 銷毀 oatpp 環(huán)境
oatpp::base::Environment::destroy();
return 0;
編譯helloworld程序
mkdir build cd build cmake .. make ./helloworld
運(yùn)行結(jié)果如下

HTTP模擬Onvif功能
啟動HTTP服務(wù)器模擬Onvif服務(wù)端,接收Onvif客戶端發(fā)送過來的http請求并響應(yīng)xml數(shù)據(jù)

項(xiàng)目背景 和 解決方案 點(diǎn) 這里
CMakeList.txt
cmake_minimum_required(VERSION 3.1)
project(helloworld)
set(CMAKE_CXX_STANDARD 11)
set(SOURCE_FILES main.cpp handler.h)
# 查找 oatpp 依賴
find_package(oatpp REQUIRED)
add_executable(${PROJECT_NAME} ${SOURCE_FILES})
# 將目標(biāo)文件與庫文件進(jìn)行鏈接
target_link_libraries(${PROJECT_NAME} oatpp::oatpp)
handler.h
// handler.h
#ifndef HANDLER_H
#define HANDLER_H
#include "oatpp/web/server/HttpRequestHandler.hpp"
#include "oatpp/web/protocol/http/incoming/Response.hpp"
#include<fcntl.h>
#include<unistd.h>
#include <sys/stat.h>
#include <unistd.h>
#define O_UNUSED(x) (void)x;
#define XML_INFO "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\" ?>"
// 自定義請求處理程序
class Handler : public oatpp::web::server::HttpRequestHandler
{
public:
// 處理傳入的請求,并返回響應(yīng)
std::shared_ptr<OutgoingResponse> handle(const std::shared_ptr<IncomingRequest>& request) override {
// O_UNUSED(request);
OATPP_LOGI("MyApp", "new connect..");
// printf("method:%d");
int fileFd = open("../test.xml",O_RDONLY);
if(fileFd < 0)
return 0;
//獲取文件大小
struct stat fileStat;
fstat(fileFd, &fileStat);
int fileSize = fileStat.st_size;
printf("fd:%d ,file size %d\n ", fileFd ,fileStat.st_size);
//申請空間存儲xml數(shù)據(jù)
char buf[1024 * 5];
memset(buf,'\0',sizeof(buf));
read(fileFd,buf,sizeof(buf));
printf("new connect..\n");
printf("buf:%s\n\n",buf);
//創(chuàng)建響應(yīng)并添加請求頭
std::shared_ptr<OutgoingResponse> resp = ResponseFactory::createResponse(Status::CODE_200, buf);
resp->putHeader("Content-Type","application/soap+xml; charset=utf-8; action=\"http://www.onvif.org/ver20/media/wsdl/GetOSDs\"");
// resp->putHeader("charset","utf-8");
// resp->putHeader("action","\"http://www.onvif.org/ver20/media/wsdl/GetOSDs\"");
resp->putHeader("X-Frame-Options","SAMEORIGIN");
close(fileFd);
return resp; //響應(yīng)請求
}
};
#endif // HANDLER_H
main.cpp
// main.cpp
#include "oatpp/web/server/HttpConnectionHandler.hpp"
#include "oatpp/network/tcp/server/ConnectionProvider.hpp"
#include "oatpp/network/Server.hpp"
#include "handler.h"
void run()
{
// 為 HTTP 請求創(chuàng)建路由器
auto router = oatpp::web::server::HttpRouter::createShared();
// 路由 GET - "/hello" 請求到處理程序
router->route("POST", "/onvif/Media2", std::make_shared<Handler>());
// 創(chuàng)建 HTTP 連接處理程序
auto connectionHandler = oatpp::web::server::HttpConnectionHandler::createShared(router);
// 創(chuàng)建 TCP 連接提供者
auto connectionProvider = oatpp::network::tcp::server::ConnectionProvider::createShared({"0.0.0.0", 7681, oatpp::network::Address::IP_4});
// 創(chuàng)建服務(wù)器,它接受提供的 TCP 連接并將其傳遞給 HTTP 連接處理程序
oatpp::network::Server server(connectionProvider, connectionHandler);
// 打印服務(wù)器端口
OATPP_LOGI("MyApp", "Server running on port %s", connectionProvider->getProperty("port").getData());
// 運(yùn)行服務(wù)器
server.run();
}
int main()
// 初始化 oatpp 環(huán)境
oatpp::base::Environment::init();
// 運(yùn)行應(yīng)用
run();
// 銷毀 oatpp 環(huán)境
oatpp::base::Environment::destroy();
return 0;test.xml
<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Header></SOAP-ENV:Header>
<SOAP-ENV:Body>
<media2:GetOSDsResponse>
</media2:GetOSDsResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
與helloworld程序的主要區(qū)別就是添加了一些請求頭以及發(fā)送xml數(shù)據(jù)
到此這篇關(guān)于oaptt搭建http服務(wù)的文章就介紹到這了,更多相關(guān)oaptt搭建http服務(wù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
OpenMP中For Construct對dynamic的調(diào)度方式詳解
在本篇文章當(dāng)中主要給大家介紹 OpenMp for construct 的實(shí)現(xiàn)原理,與他相關(guān)的動態(tài)庫函數(shù)分析以及對 dynamic 的調(diào)度方式進(jìn)行分析,希望對大家有所幫助2023-02-02
DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)與定點(diǎn)概述
本文主要介紹DSP中浮點(diǎn)與定點(diǎn)概述,很值得學(xué)習(xí)一下,需要的朋友可以參考一下。2016-06-06
C語言 數(shù)據(jù)結(jié)構(gòu)與算法之字符串詳解
這篇文章將帶大家深入了解C語言數(shù)據(jù)結(jié)構(gòu)與算法中的字符串,文中主要是介紹了字符串的定義、字符串的比較以及一些串的抽象數(shù)據(jù)類型,感興趣的可以學(xué)習(xí)一下2022-01-01
C++ 中二分查找遞歸非遞歸實(shí)現(xiàn)并分析
這篇文章主要介紹了C++ 中二分查找遞歸非遞歸實(shí)現(xiàn)并分析的相關(guān)資料,需要的朋友可以參考下2017-06-06

