c++ 网页服务器,使用C++ REST SDK实现静态网站服务器的示例

news/2024/5/13 4:08:49/文章来源:https://blog.csdn.net/weixin_28756413/article/details/119687076

目的

通过实现简易的静态网站服务器,来了解HTTP服务器的基本内容,以及C++ REST SDK如何使用。

静态网站

静态网站是指内容全部是静态的,不需要动态生成,当客户端请求指定资源时,将资源回复给客户端即可,不需要有进一步的交互;服务器上只是寄存了一些HTML、CSS、JavaScript以及资源文件。

对于静态网站,我们的HTTP服务器只需要实现GET功能,根据客户端请求的资源URI返回给客户端即可,HTTP 方法:GET 对比 POST。

实现思路

使用http_listener实现对本地端口的http请求监听;

接收到请求后根据请求的相对URI获取所请求的文件

打开文件并发送内容及内容类型

MiniHTTPServer

http_listener需要指定监听的地址,当收到资源请求时,需要确定从哪个路径取文件,并提供启动和关闭接口:

#include

#include

class MiniHTTPServer

{

public:

explicit MiniHTTPServer(utility::string_t strUrl);//根据地址创建http_listener

~MiniHTTPServer(); //关闭服务器

//设定文档根目录

void setDocumentRoot(const utility::string_t& strWWW) { m_strWWW = strWWW;};

public:

pplx::task start(); //启动服务器

pplx::task stop(); //关闭服务器

//处理错误

static void handle_error(pplx::task& t);

private:

utility::string_t m_strWWW;//根路径

std::unique_ptr<:http::experimental::listener::http_listener> m_listener;

};

构造服务器:

MiniHTTPServer::MiniHTTPServer(utility::string_t strUrl)

:m_strWWW(U(".")),m_listener(new http_listener(strUrl))

{

}

启动/停止服务器:

pplx::task MiniHTTPServer::start()

{

return m_listener->open().then([](auto t){ handle_error(t); });

}

pplx::task MiniHTTPServer::stop()

{

return m_listener->close().then([](auto t){ handle_error(t); });

}

使用方法如下:

#include "MiniHTTPServer.h"

//使能宽字符输出

#include

#include

int main(int argc, char** argv)

{

_setmode(_fileno(stdout),_O_WTEXT);

if (argc != 2)

{

std::wcout <

return -1;

}

//合成服务器地址

utility::string_t strAddr = U("http://localhost:");

strAddr.append(utility::conversions::to_string_t(argv[1]));

//构造服务器并启用

MiniHTTPServer oServer(strAddr);

oServer.start().wait();

std::wcout <

std::wcout << L"按回车关闭服务器.";

std::string strVal;

std::getline(std::cin,strVal);

//关闭服务器

oServer.stop().wait();

return 0;

}

注册HTTP的GET请求处理句柄

//处理HTTP的GET请求并回复数据

void handle_get(web::http::http_request request);

//注册

MiniHTTPServer::MiniHTTPServer(utility::string_t strUrl)

:m_strWWW(U(".")),m_listener(new http_listener(strUrl))

{

//处理GET请求

m_listener->support(methods::GET,[this](auto request){

handle_get(request);

});

}

调试用:输出请求的http_headers

现在启动服务器就可以监听客户端的GET请求了,目前可以输出请求的http_header来查看客户端请求信息:

utility::string_t MiniHTTPServer::dump_http_header(web::http::http_headers oHeader)

{

stringstream_t ss;

ss<http_header\n");

for (auto const& oVal:oHeader)

{

ss<

}

ss<

return ss.str();

}

使用方法:

void MiniHTTPServer::handle_get(web::http::http_request request)

{

auto path = request.relative_uri().path();

ucout<

ucout<

......

}

根据请求URI得到资源类型

根据后缀得到资源类型:

utility::string_t MiniHTTPServer::resource_type(const utility::string_t& strSuffix)

{

std::map<:string_t> oVals;

oVals[U(".html")] = U("text/html");

oVals[U(".js")] = U("application/javascript");

oVals[U(".css")] = U("text/css");

oVals[U(".png")] = U("application/octet-stream");

oVals[U(".jpg")] = U("application/octet-stream");

auto pIt = oVals.find(strSuffix);

if (pIt != oVals.end())

return pIt->second;

return U("application/octet-stream");

}

根据URI路径得到资源文件路径和资源类型:

std::pair<:string_t utility::string_t> MiniHTTPServer::resource(const utility::string_t& strPath)

{

//如果是ROOT,寻找index

auto strVal = (strPath == U("/"))? U("/index.html"):strPath;

fs::path oPath(m_strWWW);

auto oVal = fs::absolute(oPath/strVal);

return std::make_pair(utility::string_t(oVal),resource_type(oVal.extension()));

}

添加到GET请求处理中:

auto path = request.relative_uri().path();

ucout<

ucout<

auto oVals = resource(path);

ucout<

if (!fs::exists(oVals.first))

{

request.reply(status_codes::NotFound,U("Path not found")).then([](auto t){ handle_error(t); });

return;

}

向客户端发送资源文件

使用提供的异步输入流和请求回复接口向客户端发送资源文件:

//打开异步输入流

concurrency::streams::fstream::open_istream(oVals.first,std::ios::in).then([=](concurrency::streams::istream is){

//发送异步输入流

request.reply(status_codes::OK,is,oVals.second).then([](auto t) { handle_error(t); });

}).then([=](auto& t){

try

{

t.get();

}

catch (...)

{

//打开文件失败,返回错误信息

request.reply(status_codes::InternalError).then([](auto t) { handle_error(t); });

}

});

复制一些静态网站内容并运行

运行效果:

91e7f8f260f5

服务器输出信息

91e7f8f260f5

浏览器访问页面

总结

以上实现了一个非常简单的静态网站服务器,只有非常基本的功能,但是为懂得HTTP库使用的人揭开了HTTP服务器的面纱,得以一窥HTTP服务器的背后。

后续将继续了解C++ REST SDK提供的功能,为构造云端连接应用做好准备。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_762990.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux Command ab 网站性能压力测试工具

linux Command ab 网站性能压力测试工具 文章目录linux Command ab 网站性能压力测试工具1. 简介2. 原理3. 安装4. 参数5. 性能指标5.1 吞吐率5.2 并发连接数5.3 并发用户数5.4 用户平均请求等待时间5.5 服务器平均请求等待时间6. 实例17. 实例2&#xff1a;测试nginx性能1. 简…

(图文详细)IIS+MySQL+PHP网站开发环境搭建之篇一(腾讯云服务器学生机购买)

&#xff08;图文详细&#xff09;IISMySQLPHP网站开发环境搭建之篇一&#xff08;腾讯云服务器学生机购买&#xff09;一、注册腾讯云账号 二、购买Windows云服务器三、登录Windows云服务器四、格式化与分区数据盘 &#xff08;图文详细&#xff09;IISMySQLPHP网站开发环境…

(图文详细)通过XAMPP导入WordPress网站建立个人博客

&#xff08;图文详细&#xff09;通过XAMPP导入WordPress网站建立个人博客一、简介二、下载WordPress安装包三、启动XAMPP&#xff0c;且保证Mysql和Apache处于“Running”状态。四、在PHPMyadmin中新建和配置WordPress的数据库 &#xff08;图文详细&#xff09;通过XAMPP…

在Centos 源码安装Apache并部署网站模板

1.准备源码包 1.1 进入下载目录 [rootlocalhos ~ ]# cd /usr/local/src/ 1.2 下载软件包 ① 下载apr-1.6.5.tar.gz [rootlocalhost src] # wget https://downloads.apache.org/apr/apr-1.6.5.tar.gz ②下载apr-util-1.6.1.tar.gz [rootlocalhost src] # wget https://down…

Linux网站架构系列之Apache调优全解

环境&#xff1a; view sourceprint?1.CentOS6.4 x86_64位 采用最小化安装&#xff0c;系统经过了基本优化篇2.apache版本&#xff1a;httpd-2.4.63.apr版本&#xff1a;apr-1.4.84.apr-util版本&#xff1a;apr-util-1.5.25.pcre版本&#xff1a;pcre-7.86.源码包存放位置…

容器方式搭建免费的表白网站(2022.9.25更新)

目录效果图拉取镜像运行容器访问制作方式效果图 拉取镜像 docker pull registry.cn-zhangjiakou.aliyuncs.com/dwz/softwares:boy921运行容器 docker run -di -p 80:80 -e BOYNAME王晨 -e GIRLNAME王舒涵 -e FIRSTTIME2022/9/21 -e STARTTIME2022,8,21 registry.cn-zhangjia…

24.网站更新数据监控-1

24.网站更新数据监控-1 一.scrapy 对网站是否更新做监控1.spider.py # -*- coding: utf-8 -*- import scrapy import time import re from WEB.conmon.md5_tool import md5_encodefrom WEB.items import WebItemclass CompanyInfoSpider(scrapy.Spider):name wenzhouallowed_d…

网站忘记密码怎么找回?

网站忘记密码怎么找回? 两个方法 方法一&#xff1a; 登录数据库&#xff0c;把password 下面的这一串加密串 解密一下。我至今没这样弄过&#xff0c;原理是这样&#xff0c;但是我没找到好用的md5 解密网站。一般的都要收费的。 方法二: 在数据库重置一个简单的密码&#xf…

手机网站按住放大图片_让渣渣像素图片复活,推荐两个无损放大图片的网站

老Y在之前的文章中推荐过不少寻找高清大图的网站&#xff08;收集了3年的网站和大家分享&#xff09;​虽然大多数情况下能够找到比较高清的图片&#xff0c;但有些图片确实很难找到高清的&#xff0c;比如一些企业的Logo、专业性设备照片等&#xff0c;只能在官网上找到一些小…

建站公司需要结合哪方面来制作网站?

企业建网站目的就是为了推广自己品牌、产品、业务等项目。对一个企业来讲&#xff0c;建设网站可迅速树立自已的品牌形象&#xff0c;来提高知名度。但对于建设网站公司来讲&#xff0c;既要结合建站技术&#xff0c;又要根据企业需要来打造用户喜欢的网站。 可能有人会想&…

代码内容变成图片_SEO代码优化之img图片标签

在网站的页面中&#xff0c;图片是重要的组成元素之一&#xff0c;所以&#xff0c;对网站img图片进行SEO优化&#xff0c;不仅有利于用户的浏览体验提升&#xff0c;也有利于搜索引擎蜘蛛的抓取识别&#xff0c;还可以丰富页面的内容&#xff0c;提升页面得分&#xff0c;有利…

50万以内的网站服务器系统配置,每秒50万次请求 你的Web服务器能办到吗?

现在的 HTTP 服务器性能非常之高&#xff0c;在一些老的服务器上一样可以有非常棒的表现&#xff0c;下面是对 Nginx 1.0.14 自带的默认首页进行压力测试的结果&#xff0c;图表显示每秒请求数和并发连接数&#xff1a;在这张图中 Nginx 的最高处理能力达到每秒 50w 的请求数处…

爬取17k小说网站

传入网站的首页的url&#xff0c;获取首页多个书籍对应书名和对应书名的url 书籍对应书名和对应书名的url如下 部分代码如下 def getBook(url):getBookList []chrome webdriver.Chrome()chrome.get(url)texts chrome.find_elements_by_xpath(//ul[class"Top1"]/li…

Django的模板继承和加载以及常见网站类型

PyCharm快捷键 Ctrlf查找 Ctrlr替换 做项目过程中注意事项 前面记得加斜杠 代表从根匹配&#xff0c;加/很重要。不加的话代表从当前的目录开始。 模板继承 针对网站所有的网页通常使用一个模板&#xff0c;所有代码都有相同部分&#xff0c;为了减少代码冗余&#xff0c;方便代…

python做的网站_如何用Python做一个网站?

Install pip install Django 2. 新建一个2113工程 django-admin startproject mysite 然后5261&#xff0c;4102我们会得到一个这样的文件结构请点击输入图片描述 python manage.py runserver 0.0.0.0:8888 然后&#xff0c;你就可1653以在浏览器地址栏中输入http://127.0.0.1:…

分类信息网站源码_SEO优化:教你三招做好分类信息网站优化

各位小伙伴大家好~我是新人小编艾斯~今天给大家分享下分类信息网站优化分类信息网目前看似已经被赶集网、58同城这样的超大网站垄断&#xff0c;但是针对地方的分类信息&#xff0c;还是有做头的。比如朋友的“重庆二手it论坛”&#xff0c;就利用小众领域的分类信息进行突破&a…

网站备案负责人_网站icp备案流程是怎样的

目前在国内知名系统主机作网站&#xff0c;都是要按照国家法规来备案网站主办人信息&#xff0c;与以网站内容信息用途&#xff0c;都是要详细备案。那么&#xff0c;网站icp备案流程是怎样的?一起来了解一下吧。1.首先选择你备案的运营商&#xff0c;这里以百度云为例。注册好…

powerbi中python网站数据_PowerBI/Excel批量爬取网页数据超详细流程

前面介绍PowerBI数据获取的时候&#xff0c;曾举了一个从网页中获取数据的例子&#xff0c;但当时只是爬取了其中一页数据&#xff0c;这篇文章来介绍如何用PowerBI批量采集多个网页的数据。(Excel中的Power query可以同样操作)本文以智联招聘网站为例&#xff0c;采集工作地点…

网站克隆工具-httrack安装使用教程

1、安装 sudo apt-get isntall httarck 2、启动httrack cd 到一个文件夹 启动 httrack -*.gif www.*.com/*.zip -*img_*.zip 之后一路回车就行了&#xff0c;httrack会爬取所有网站的js文件以及图片保存到相应的文件夹中 3、克隆完成 过一会提示 Done.K Thanks for usi…

网站被百度提示有风险,该如何解决?网站被黑怎么办?

网站在最近被百度提示有风险&#xff0c;导致网站流量急剧的下滑&#xff0c;从百度点击进去会直接跳转到什 么BCdu博的网站上去&#xff0c;360提示&#xff1a;未经证实的BCdu博网站您访问的网站含有未经证实的境外BC网站的相关内容&#xff0c;可能给您造成财产损失&#xf…