Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Теория и практика механизма "Кто on-line"
 
 автор: DDK   (03.11.2005 в 12:53)   письмо автору
 
 

Не знаю, почему, но поиск не дал результатов. Объясните мне пожалуйста теорию и, желательно, практитку (простейший пример) скрипта "Кто сейчас на сайте в on-line" ! Как это делается ?

   
 
 автор: Gerom   (03.11.2005 в 12:56)   письмо автору
 
   для: DDK   (03.11.2005 в 12:53)
 

По IP адресу можно выяснить, а данные заносить в БД вместе с датой и временем захождения на сайт.

   
 
 автор: DDK   (03.11.2005 в 13:00)   письмо автору
 
   для: Gerom   (03.11.2005 в 12:56)
 

Мне не понятна сама теория... т.е. напирмер, как определить, что зверь (читай юзер) ушёл с сайта... как это всё делается ?!

   
 
 автор: Gerom   (03.11.2005 в 13:04)   письмо автору
 
   для: DDK   (03.11.2005 в 13:00)
 

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

   
 
 автор: Axxil   (03.11.2005 в 13:30)   письмо автору
 
   для: DDK   (03.11.2005 в 13:00)
 

Теория такая:
Когда пользовательприходит на сайт, мы по кукам определяем его. Если это зарегистрированный пользователь, то его идентификатор сессии пишется в базу вместе с его id и временем последнего обновления страницы. Далее из этой таблицы делается элементарная выборка:

<?
$sql
='select * from session where last_time>date_sub(NOW(), interval 5 minute)';
$query=mysql_query($sql);
while(
$r=mysql_fetch_assoc($query)){
  echo 
"Кто он-лайн:<br>";
  echo 
$r['ID']." - ".$r['last_ttime'];
}
?>

естественно вместо ID подтягиваются ники из таблицы users

Т.е если пользователь не обновил страницу в течении 5 минут, он будет считаться ушедшим

Далее установив "время жизни пользователей" на сайте т.е. переодичность очистки таблицы с сессиями мы устанавливаем промежуток после которого обновление страницы пользователем будет считаться как новое посещение.

Ну и естественно в начале каждой страницы нужно обновлять таблицу сессий записывая время refresha

   
 
 автор: DDK   (03.11.2005 в 13:59)   письмо автору
 
   для: Axxil   (03.11.2005 в 13:30)
 

Спасибо, вот теперь я понял принцип ! Встречный вопрос - а очищать таблицу лучше в том же цикле выборки ? Имхо просто это будет занимать не малое время, и соотв. сильно нагружать скрипт, особенно, если я хочу сделать вывод online-зверей на каждой странице сайта... может есть какая-то хитринка по этому поводу ?

   
 
 автор: cheops   (03.11.2005 в 14:06)   письмо автору
 
   для: DDK   (03.11.2005 в 13:59)
 

А нет просто одним запросом
$sql='delete from session where last_time<date_sub(NOW(), interval 5 minute)';

   
 
 автор: cheops   (03.11.2005 в 14:03)   письмо автору
 
   для: DDK   (03.11.2005 в 12:53)
 

Вот наиболее интересные темы форума, посвящённые обсуждению данного вопроса
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=7013
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=545
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=1235
http://www.softtime.ru/forum/read.php?id_forum=3&id_theme=1717
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=1992
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=319
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=196
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=119
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=1235
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=393
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=357
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=275
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=150
http://www.softtime.ru/forum/read.php?id_forum=3&id_theme=1717

   
 
 автор: DDK   (03.11.2005 в 14:08)   письмо автору
 
   для: cheops   (03.11.2005 в 14:03)
 

Ууух ! читать и читать мне, чувствую ! Спасибки, как всегда, отличн сработано !

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования