Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Пример клиент-серверной системы передачи сообщений
Форум на CrossPlatform.RU > Библиотеки > Qt > Qt Ввод/Вывод, Сеть. Межпроцессное взаимодействие
DeathKnight
может быть, есть у кого-нибудь пример "клиент-серверной системы передачи сообщений".
все, что нашел в нете, слишком сложно. тот же qutim.
извините за беспокойство. за ранее спасибо.
kwisp
DeathKnight,
а стандартные примеры поставляемые с библиотекой почему не смотрим?
и + поищи по форуму QTcpSocket QTcpServer QUdpSocket и проч.... для разнообразия.
ViGOur
Посмотри: Network Examples
DeathKnight
kwisp, смотрел, просто этого мне не хватает для представления, как разработать программу.
буду ковырять. спс.
kwisp
DeathKnight,
раз не хватает стандартных примеров -- задавай конкретные вопросы.
этот вопрос кроме как ссылки на примеры уж прости ничего не заслуживает.
Цитата(DeathKnight @ 28.3.2010, 16:12) *
может быть, есть у кого-нибудь пример "клиент-серверной системы передачи сообщений".
все, что нашел в нете, слишком сложно. тот же qutim.
извините за беспокойство. за ранее спасибо.
DeathKnight
хм.. тогда так. я придумал сделать на сервере:
-простой гуи для контроля состояния.
-сам tcpserver отправить в отдельный поток
-для каждого сокета пользователя также отдельный поток(клиент как наследник qthread с указателем на qtcpsocket)
-в объекте сервера qmap(id и ссылка на объект клиент-поток-сокет) для определения кому пересылать пришедшее сообщение
- и класс сообщения, в начале которого quint, где лежит величина всего объекта, а дальше параметры(либо id от кого и кому и сообщение, либо служебные сообщения(авторизация и т.п.))

оправдан такой подход или это будет довольно сложно для реализации? пишу курсовой.
kwisp
DeathKnight,
тут вопрос, на сколько много соединений ты хочешь обслуживать и как много данных передавать. если объемы данных не большие и соединений не много то..... если кол-во соединений большое и объемы данных велики то всё намного сложнее по-моему.
если по-простому я бы попробовал сделать так.
никаких потоков.
-- сервер слушает порт(для гибкости порт можно передавать через параметр командной строки или гуй или файл конфигурации). как только кто-то стучится соединиться ему выделяется новый сокет с новым портом и далее общение с клиентом уже через новый сокет.
-- клиент стучится на сервер:порт(заданый через гуй, командную строку, файл конфигурации) ему выделяют порт и он уже по этому порту общается сервером.
-- класс сообщения с заголовком quint, вроде нормально у меня сделано так же пока сбоев не было. прочти соседние темы на счет затыков с размерами сообщений, перемешении байтов, корректном вычитывании из сокета.

пробуй. пиши код сюда.
П.С. зачем тебе QMap для хранения идентификаторов клиентов если не важен порядок используй QHash или вектор., можно и обычным массивом обойтись если извесно максимальное колличество клиентов.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Форум IP.Board © 2001-2024 IPS, Inc.