我正在开发一个http解析器,看起来像boost.beast很好。但是,我还有一些问题:
***假设已通过boost.asio套接字收到HTTP请求POST数据。存储在std :: string缓冲区中。
关于如何提取http标头字段及其值(一个接一个),是否有任何好的示例?我假设它将是一个迭代器方法,但我尝试了几种方式,仍然无法工作。
如何提取http正文?
非常感谢。
答案 0 :(得分:5)
从一个简单的例子开始:https://www.boost.org/doc/libs/develop/libs/beast/example/http/client/sync/http_client_sync.cpp
// Declare a container to hold the response
http::response<http::dynamic_body> res;
// Receive the HTTP response
http::read(socket, buffer, res);
响应对象已包含所有商品:
for(auto const& field : res)
std::cout << field.name() << " = " << field.value() << "\n";
std::cout << "Server: " << res[http::field::server] << "\n";
您也可以直接传输整个响应对象:
std::cout << res << std::endl;
std::cout << "Body size is " << res.body().size() << "\n";
要实际使用&#34; dynamic_body&#34;,请使用标准的Asio缓冲区操作:
#include <boost/asio/buffers_iterator.hpp>
#include <boost/asio/buffers_iterator.hpp>
std::string body { boost::asio::buffers_begin(res.body().data()),
boost::asio::buffers_end(res.body().data()) };
std::cout << "Body: " << std::quoted(body) << "\n";
或者,请参阅
beast::buffers_to_string
显然,使用string_body
:
std::cout << "Body: " << std::quoted(res.body()) << "\n";