Пример отдыха

Это первый раз, когда я использую restbed или что-либо, связанное с HTTP (программирование).
Поэтому я добавил restbed в свой проект и попытался запустить простой пример, показанный на главной странице github.

#include <memory>
#include <cstdlib>
#include <restbed>

using namespace std;
using namespace restbed;

void post_method_handler( const shared_ptr< Session > session )
{
const auto request = session->get_request( );

int content_length = request->get_header( "Content-Length", 0 );

session->fetch( content_length, [ ]( const shared_ptr< Session > session, const Bytes & body )
{
fprintf( stdout, "%.*s\n", ( int ) body.size( ), body.data( ) );
session->close( OK, "Hello, World!", { { "Content-Length", "13" } } );
} );
}

int main( const int, const char** )
{
auto resource = make_shared< Resource >( );
resource->set_path( "/resource" );
resource->set_method_handler( "POST", post_method_handler );

auto settings = make_shared< Settings >( );
settings->set_port( 1984 );
settings->set_default_header( "Connection", "close" );

Service service;
service.publish( resource );
service.start( settings );

return EXIT_SUCCESS;
}

Останавливается в строке: service.start (настройки);

Я проверил функцию запуска, используется какой-то особенный обработчик, но я не знаю, как на самом деле должен работать тест.

Может ли кто-нибудь помочь мне понять, если я делаю что-то не так, тест работает как положено или что-то еще?

Благодарю.

Отредактировано: объяснение очень помогло. Итак, я попробовал код, который вы разместили, и получил это:

$> curl -w'\n' -v -X GET 'http://localhost:1984/resource'
* Hostname was NOT found in DNS cache
*   Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 1984 (#0)
> GET /resource HTTP/1.1
> User-Agent: curl/7.35.0
> Host: localhost:1984
> Accept: */*
>
< HTTP/1.1 501 Not Implemented
* no chunk, no close, no size. Assume close to signal end
<
* Closing connection 0

Я предполагаю, что сообщение «Не реализовано» не очень хорошая вещь. Не могли бы вы помочь мне с этим?

2

Решение

Обработчик Service :: start блокируется. Поток, который вызывает этот метод, будет использоваться для обработки входящих запросов.

Если вы хотите продолжить обработку, установите готовый обработчик. Этот обработчик будет вызываться, когда служба запущена и готова обрабатывать запросы.

сервер

#include <thread>
#include <memory>
#include <chrono>
#include <cstdlib>
#include <restbed>

using namespace std;
using namespace restbed;

void get_method_handler( const shared_ptr< Session > session )
{
session->close( OK, "Hello, World!", { { "Content-Length", "13" }, { "Connection", "close" } } );
}

void service_ready_handler( Service& )
{
fprintf( stderr, "Hey! The service is up and running." );
}

int main( const int, const char** )
{
auto resource = make_shared< Resource >( );
resource->set_path( "/resource" );
resource->set_method_handler( "GET", get_method_handler );

auto settings = make_shared< Settings >( );
settings->set_port( 1984 );

auto service = make_shared< Service >( );
service->publish( resource );
service->set_ready_handler( service_ready_handler );
service->start( settings );

return EXIT_SUCCESS;
}

клиент

curl -w'\n' -v -X GET 'http://localhost:1984/resource'

3

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]