Comet и php

MS
На сайте с 25.01.2014
Offline
0
597

Добрый вечер.

Собираюсь писать сайт (форум), хотелось бы делать с поддержкой HistoryAPI, соответственно, пользователи должны моментально уведомляться о новых сообщениях в той теме, в которой они сейчас находятся. То же самое и с личными сообщениями.

Приглянулся модуль nginx-push-stream-module, все вроде бы хорошо, но в этом случае невозможно проверить личность пользователя (и, собственно, сделать проверку, может ли подключаться пользователь к данному каналу).

Единственное, что приходит в голову - это шифрование имен каналов, но этого явно будет недостаточно.

Как вообще реализовываются подобные системы? (с проверкой подлинности пользователя)

X
На сайте с 11.06.2009
Offline
34
#1

Имя канала - набор случайных символов. Так же работают и обычные сессии - при каждом запросе клиент гоняет на сервер идентификатор сессии, состоящий из некоторого количества случайных символов

MS
На сайте с 25.01.2014
Offline
0
#2

Набор СЛУЧАЙНЫХ символов - не подходит, т.к. надо будет знать, куда отправлять. Только если что-то типа $channel_name = md5($name), но в этом случае при сильном желании те, кому нужно будет получать уведомления для данного канала различными способами смогут получить доступ.

Имя канала = идентификатор сессии и туда отправлять данные - вариант, но в этом случае придется хранить идентификаторы сессий пользователя и, собственно, хранить список тех, кто должен получить уведомление (для каждого источника, например, тема на форуме).

Можно сделать паблик каналы и приватные каналы, но у меня из паблик данных будут только новости на главной, так что, не особо имеет смысл. Конечно, можно определять доступность страницы (например, темы) для гостей (а значит, это могут читать все пользователи), но это лишнее, как по мне.

В ASP.NET (SignalR) есть возможность проверки личности пользователя как при подключении, так и при передаче команды хабу. Но там, как я понимаю, это реализовано при помощи модуля для IIS, на php такое невозможно.

Оптимизайка
На сайте с 11.03.2012
Offline
396
#3

Гоняйте json по каналу, положите туда логин и куку авторизации, а в php-обрабтчике это проверяйте

⭐ BotGuard (https://botguard.net) ⭐ — защита вашего сайта от вредоносных ботов, воровства контента, клонирования, спама и хакерских атак!
MS
На сайте с 25.01.2014
Offline
0
#4

Немного не понял. Вы предлагаете просто запрашивать php скрипт, аля long-polling? Я планирую ставить nginx + php. Не помрет ли php от большого количества висячих запросов?

Оптимизайка
На сайте с 11.03.2012
Offline
396
#5

Так, кажется я не о том подумал. Вы поподробнее о задаче. Нужно не давать подписываться на прослушивание канала некоторым подписчикам или не давать им публиковать?

MS
На сайте с 25.01.2014
Offline
0
#6

Не давать подписываться на каналы.

Например, есть тема на форуме. Есть канал thread_123, где 123 - айди темы. Собственно на этот канал должны иметь возможность подписываться только те, кто может видеть данную тему.

Оптимизайка
На сайте с 11.03.2012
Offline
396
#7

Ну если такая схема как:

клиент -> авторизация -> сервер возвращает список каналов, на которые подписываться можно

не устраивает (имена каналов неугадываемые случайные), то тогда только форки - https://github.com/Kronuz/nginx_http_push_module (сам не пробовал)

Либо не передавать информацию, которую не должны видеть неавторизованные пользователи. Например, не запрещать никому подписываться на каналы тем форума, а push'ить сервером подписчикам только id новых сообщений. Права проверять соответственно при загрузке этих сообщений.

MS
На сайте с 25.01.2014
Offline
0
#8
Либо не передавать информацию, которую не должны видеть неавторизованные пользователи. Например, не запрещать никому подписываться на каналы тем форума, а push'ить сервером подписчикам только id новых сообщений. Права проверять соответственно при загрузке этих сообщений.

Отличная идея. Спасибо. Так и сделаю.

DiAksID
На сайте с 02.08.2008
Offline
236
#9

Берите Meteor и не партесь - реально вменяемый движок с минимальным порогом вхождения, пара вечеров - и в дамках 😂 юзвери не "уведомляться" будут, а просто увидят новые сабжи без обновления страницы.

всё одно по настоящему реактивное приложение иначе чем на Ноде сейчас не сделать...

show must go on !!!...

Авторизуйтесь или зарегистрируйтесь, чтобы оставить комментарий