- http_server库的介绍
libhttpserver是一款C++编写的轻量级HTTP服务器库,可以用于开发各种基于HTTP的应用程序和服务。在Gitcode上开源。
- libhttpserver功能介绍:
创建一个HTTP服务器,并监听指定的端口。
处理HTTP请求,并返回响应。
支持GET、POST、PUT、DELETE等HTTP方法。
支持HTTP/1.1协议。
可以自定义处理器,根据不同的URL路径执行不同的操作。
支持WebSocket协议,可以方便地创建WebSocket服务器。
- 应用场景
libhttpserver适用于需要快速搭建基于HTTP服务的各种应用场景,包括但不限于:
开发Web应用程序或服务
实现嵌入式设备上的HTTP服务器功能。
在本地测试和调试HTTP相关的功能。
构建支持WebSocket的服务应用。
- 特点与优势
与其他HTTP服务器库相比,libhttpserver具有以下几个显著的特点和优势:
简单易用:libhttpserver提供了简洁明了的API,开发者能够快速上手并进行实际开发。
轻量高效:该库体积小巧,性能卓越,特别适合资源有限的环境。
高度可定制:通过自定义处理器,可以根据自己的需求灵活处理不同类型的HTTP请求。
兼容性好:支持多种HTTP方法和HTTP/1.1协议,满足大多数应用场景的需求。
支持WebSocket。内置WebSocket支持,在一套代码中实现HTTP和WebSocket功能
main.cpp
ThreadBase.h文件实现多线程分离:实现ThreadBase多线程-CSDN博客
#include "HttpSrvHandler.h"
#include "ThreadBase.h"//这个就是实现线程分离的头文件
#include <iostream>
using namespace thread_base;
int main()
{
HttpSrvHandler* pHttpSrvHandler = new HttpSrvHandler();
if(false == pHttpSrvHandler->Init())
{
std::cout<<"httpserver init error\n";
}
StartDetachThread(pHttpSrvHandler);//线程分离
std::cout<<"HttpSrvHandler Start Ok..."<<std::end;
char c;
do
{
std::cout<<"Press q or Q to exit...\n\n";
c = getchar();
} while (c != 'q' && c != 'Q');
std::cout<<"Exit By q or Q"<<std::end;
pHttpSrvHandler->stop();
delete pHttpSrvHandler;
pHttpSrvHandler = NULL;
std::cout<<"HttpSrvHandler Stop Ok...\n";
return 0;
}
ThreadBase.h文件是C++实现线程分离的一个文件。
HttpSrvHandler.h
#include "ThreadBase.h"
#include "http_server.h"
#include <string>
#include <map>
using namespace thread_base;
class HttpSrvHandler : public ThreadBase
{
public:
HttpSrvHandler();
virtual ~HttpSrvHandler();
bool Init();
private:
virtual void loop() override;
private:
HttpServer *httpSrv;
};
HttpSrvHandler.cpp
#include "HttpSrvHandler.h"
#include <iostream>
#include <fstream>
using namespace std;
static int read_local_file(const string& path, string& out_string)
{
ifstream in(path.c_str(), ios::binary);
if (!in.is_open())
{
return -1; //打开失败
}
stringstream ss;
ss << in.rdbuf();
out_string = ss.str();
in.close();
return 0;
}
void getpicture_callback(const Request* pRecvInfo, Response* respCB, void* arg)
{
if (pRecvInfo == NULL)
{
return;
}
string req_uri = pRecvInfo->head.path;
if (req_uri.empty())
{
return;
}
string pic_data;
if (read_local_file(req_uri, pic_data) != 0)
{
string reply = "<html>服务器收到请求,但未找到该图片。查找路径为 " + req_uri + " </html>";
Http_RespBody(HTTP_NOT_FOUND, respCB, reply.c_str(), reply.size());
std::cout<<"Unknow path: %s", req_uri.c_str()<<std::end;
}
else
{
if (pic_data.empty())
{
string reply = "<html>图片文件为空,查找路径为 " + req_uri + " </html>";
Http_RespBody(HTTP_NOT_FOUND, respCB, reply.c_str(), reply.size());
std::cout<<"Empty file: "<< req_uri.c_str()<<std::end;;
}
else
{
Http_RespBody(HTTP_OK, respCB, pic_data.c_str(), pic_data.length());
}
}
return ;
}
HttpSrvHandler::HttpSrvHandler()
{
}
HttpSrvHandler::~HttpSrvHandler()
{
Http_Destory(httpSrv);
}
bool HttpSrvHandler::Init()
{
HttpConfig cfg = Http_GetDefaultCfg();
cfg.port = 9999;//端口号
//还可以设置监听地址,默认监听本地网卡。多网卡的时,需要设置
cfg.tcpBuf = (1 << 20) * 5; // 设置接收缓冲去的大小 5M
httpSrv = Http_Init(&cfg);
Http_CB(httpSrv, (HttpCBFun)getpicture_callback, nullptr);
return true;
}
void HttpSrvHandler::loop()//因为loop函数是基类的纯虚函数,所以要实现。
{
}