oaptt搭建http服務的過程詳解
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 項目,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}) # 將目標文件與庫文件進行鏈接 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: // 處理傳入的請求,并返回響應 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)建服務器,它接受提供的 TCP 連接并將其傳遞給 HTTP 連接處理程序 oatpp::network::Server server(connectionProvider, connectionHandler); // 打印服務器端口 OATPP_LOGI("MyApp", "Server running on port %s", connectionProvider->getProperty("port").getData()); // 運行服務器 server.run(); } int main() // 初始化 oatpp 環(huán)境 oatpp::base::Environment::init(); // 運行應用 run(); // 銷毀 oatpp 環(huán)境 oatpp::base::Environment::destroy(); return 0;
編譯helloworld程序
mkdir build cd build cmake .. make ./helloworld
運行結果如下
HTTP模擬Onvif功能
啟動HTTP服務器模擬Onvif服務端,接收Onvif客戶端發(fā)送過來的http請求并響應xml數據
項目背景 和 解決方案 點 這里
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}) # 將目標文件與庫文件進行鏈接 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: // 處理傳入的請求,并返回響應 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數據 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)建響應并添加請求頭 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; //響應請求 } }; #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)建服務器,它接受提供的 TCP 連接并將其傳遞給 HTTP 連接處理程序 oatpp::network::Server server(connectionProvider, connectionHandler); // 打印服務器端口 OATPP_LOGI("MyApp", "Server running on port %s", connectionProvider->getProperty("port").getData()); // 運行服務器 server.run(); } int main() // 初始化 oatpp 環(huán)境 oatpp::base::Environment::init(); // 運行應用 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數據
到此這篇關于oaptt搭建http服務的文章就介紹到這了,更多相關oaptt搭建http服務內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
OpenMP中For Construct對dynamic的調度方式詳解
在本篇文章當中主要給大家介紹 OpenMp for construct 的實現原理,與他相關的動態(tài)庫函數分析以及對 dynamic 的調度方式進行分析,希望對大家有所幫助2023-02-02