crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

 
Ответить в данную темуНачать новую тему
> Нужна помощь в реализации сервера на boost::asio, Как узнать о входящем соединении?
niXman
  опции профиля:
сообщение 26.5.2009, 15:00
Сообщение #1


Участник
**

Группа: Участник
Сообщений: 169
Регистрация: 18.6.2008
Пользователь №: 204

Спасибо сказали: 1 раз(а)




Репутация:   0  


Доброго времени суток!
В общем суть вопроса Вам понятна.
Как реализовать сие при помощи Qt, не вопрос! А вот boost для меня новое.
Пересмотрел все примеры для asio, многое понял. Но так и не понял как получить сигнал о входящем соединении.
Может кто-то реализовывал такое ранее? Поделитесь примером.

Спасибо!
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Andrew Selivanov
  опции профиля:
сообщение 26.5.2009, 16:06
Сообщение #2


Участник
**

Группа: Участник
Сообщений: 249
Регистрация: 9.10.2007
Из: Москва
Пользователь №: 3

Спасибо сказали: 15 раз(а)




Репутация:   6  


Цитата(niXman @ 26.5.2009, 16:00) *
Доброго времени суток!
В общем суть вопроса Вам понятна.
Как реализовать сие при помощи Qt, не вопрос! А вот boost для меня новое.
Пересмотрел все примеры для asio, многое понял. Но так и не понял как получить сигнал о входящем соединении.
Может кто-то реализовывал такое ранее? Поделитесь примером.

Спасибо!

В каком смысле сигнал о входящем соединении? Там через обработчики всё делается, для входящего соединения смотри пример asio\example\timeouts\accept_timeout.cpp
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
niXman
  опции профиля:
сообщение 26.5.2009, 16:39
Сообщение #3


Участник
**

Группа: Участник
Сообщений: 169
Регистрация: 18.6.2008
Пользователь №: 204

Спасибо сказали: 1 раз(а)




Репутация:   0  


Andrew Selivanov, Т.е. В Кут, QTcpServer испускает сигнал newConnection() при подключении. И с помощью QTcpServer::nextPendingConnection() я получаю сокет. С которым и работаю.
Как это в Бусте реализовать, понятия не имею... :unsure:
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Andrew Selivanov
  опции профиля:
сообщение 26.5.2009, 17:18
Сообщение #4


Участник
**

Группа: Участник
Сообщений: 249
Регистрация: 9.10.2007
Из: Москва
Пользователь №: 3

Спасибо сказали: 15 раз(а)




Репутация:   6  


Цитата(niXman @ 26.5.2009, 17:39) *
Andrew Selivanov, Т.е. В Кут, QTcpServer испускает сигнал newConnection() при подключении. И с помощью QTcpServer::nextPendingConnection() я получаю сокет. С которым и работаю.
Как это в Бусте реализовать, понятия не имею... :unsure:

Там модель другая (в ASIO во всяком случае). Рассмотри внимательно примеры и почитай доки. Особенно интересны примеры HTTP и ECHO серверов.
Раскрывающийся текст

//
// accept_timeout.cpp
// ~~~~~~~~~~~~~~~~~~
//
// Copyright (c) 2003-2008 Christopher M. Kohlhoff (chris at kohlhoff dot com)
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//

#include <boost/asio.hpp>
#include <boost/bind.hpp>
#include <boost/date_time/posix_time/posix_time_types.hpp>
#include <iostream>

using namespace boost::asio;
using boost::asio::ip::tcp;

class accept_handler
{
public:
  accept_handler(io_service& ios)
    : io_service_(ios),
      timer_(ios),
      acceptor_(ios, tcp::endpoint(tcp::v4(), 32123)),
      socket_(ios)
  {
    // установить обработчик который будет вызван при accept
    acceptor_.async_accept(socket_,
        boost::bind(&accept_handler::handle_accept, this,
          boost::asio::placeholders::error));

    timer_.expires_from_now(boost::posix_time::seconds(5));
    timer_.async_wait(boost::bind(&accept_handler::close, this));
  }

  //обработчик, который будет вызван при accept
  //чтобы дальше получить что то из сокета, прописываешь следующий обработчик для read
  void handle_accept(const boost::system::error_code& err)
  {
    if (err)
    {
      std::cout << "Accept error: " << err.message() << "\n";
    }
    else
    {
      std::cout << "Successful accept\n";
    }
  }

  void close()
  {
    acceptor_.close();
  }

private:
  io_service& io_service_;
  deadline_timer timer_;
  tcp::acceptor acceptor_;
  tcp::socket socket_;
};

int main()
{
  try
  {
    io_service ios;
    accept_handler ah(ios);
    ios.run();
  }
  catch (std::exception& e)
  {
    std::cerr << "Exception: " << e.what() << "\n";
  }

  return 0;
}


Вот пример для read
Раскрывающийся текст

//asio\example\echo\async_tcp_echo_server.cpp
//...
  void start()
  {
    socket_.async_read_some(boost::asio::buffer(data_, max_length),
        boost::bind(&session::handle_read, this,
          boost::asio::placeholders::error,
          boost::asio::placeholders::bytes_transferred));
  }

  void handle_read(const boost::system::error_code& error,
      size_t bytes_transferred)
  {
    if (!error)
    {
      boost::asio::async_write(socket_,
          boost::asio::buffer(data_, bytes_transferred),
          boost::bind(&session::handle_write, this,
            boost::asio::placeholders::error));
    }
    else
    {
      delete this;
    }
  }
//...
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
niXman
  опции профиля:
сообщение 26.5.2009, 17:47
Сообщение #5


Участник
**

Группа: Участник
Сообщений: 169
Регистрация: 18.6.2008
Пользователь №: 204

Спасибо сказали: 1 раз(а)




Репутация:   0  


Andrew Selivanov, Спасибо! Попытаюсь разобраться...
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 22.11.2024, 15:35