Издательский дом ООО "Гейм Лэнд"СПЕЦВЫПУСК ЖУРНАЛА ХАКЕР #28, МАРТ 2003 г.

ЗНАЙ ВРАГА В ЛИЦО! - статистика посещений по-простому

 

Спецвыпуск Xakep, номер #028, стр. 028-080-1


ДАО-КЭ-ДАО ФЭЙ-ЧАН-ДАО

Есть много способов определить, кто и в каких количествах лазит по твоим страничкам. Давай попробуем найти и разобрать несколько простейших движков для достижения этой цели. Все движки на PHP, потому что это, наверное, самый простой способ. Можно, конечно, поставить на свой сайт чужие счетчики или пользоваться готовой статистикой сервера, но эти способы не в счет. Попробуем сами, чего-нибудь наскриптовать и прикрутить.

КТО?

Что ты хочешь знать о пользователе? Все, вплоть до размера колготок и диаметра сосков! Но современные технологии нам такой великолепной возможности, к сожалению, не предоставляют. Все в будущем, а пока мы можем вытащить то, что хранится в переменных среды.

Чтобы узнать список всех переменных, которые поддерживает твой браузер, нужно заюзать таг:

<?php phpinfo()?>

Инфа о браузере и операционной системе и языке хранится в переменной HTTP_USER_AGENT; чтобы вывести ее содержимое, забивай таг:

<?php echo $HTTP_USER_AGENT; ?>

Запомни эту переменную, она не простая, а золотая, потому что по ней часто можно отличить поисковую машину от рядового пользователя. Поисковики часто пишут свое имя в эту переменную.

Полезно также знать, с какой странички пользователь к тебе пришел, то есть кто такой хороший дал ссылочку на твою заплесневелую пагу? Этот адрес выясняется легко:

<?php echo $HTTP_REFERER; ?>

Чтобы пользователи не наглели, полезно будет хранить их IP-шники. То есть можно будет вычислить адреса любителей порнушки. Конечно, IP-адрес у юзера может быть не постоянный, но все-таки это внесет какую-то стабильность. Это простейший способ определить, тот же пользователь заходит на страничку или другой?

Вывод осуществляем тагом:

<?php echo $REMOTE_ADDR; ?>

Не отходя от кассы, можно проверить порт, с которого пришел запрос:

<?php echo $REMOTE_PORT; ?>

Ну и еще полезно знать, какую страничку пользователь запросил:

<?php echo $REQUEST_URI; ?>

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

КОГДА?

Как только пользователь зайдет на нашу страничку, он сразу же активизирует таг:

<?php $kogda=date('H:i:s, d m Y'); ?>.

Функция date() запишет в переменную kogda часы, минуты, секунды, день, месяц и год. Подробную расшифровку смотри по ссылке: http://www.west.com.ua/doc/php/learn_php3/7.html

СОХРАНИТЬ!

Кто и когда, мы знаем, теперь осталось это сохранить в файле. Для этого надо заюзать функцию открытия файла и установки указателя fopen(), в скобках указывай путь к файлу. Процедура fwrite() - запишет в файл по указателю полученные данные, а процедура fclose() закроет файл.

ДВИЖОК: с каких страниц к тебе ходят

АДРЕС: http://www.evilwalrus.com/viewcode/605.php

Самый наипростецкий движок, ничего напутать невозможно. Просто сохраняет в текстовом файле адреса страниц, с которых пользователи пришли на твою пагу. Эти адреса он берет из переменной HTTP_REFERER.

ДВИЖОК: когда? кто? откуда? под чем?

АДРЕС: http://www.evilwalrus.com/viewcode/56.php

Ну а тут движок немного посложнее. Засасываются: дата, с помощью функции date(), айпишник юзера через переменную REMOTE_ADDR, откуда пришел через HTTP_REFERER и с чем пришел (браузер) HTTP_USER_AGENT. Причем все это записывается в формате HTML файла за счет того, что переменные вставлены в заготовку HTML-документа. В результате имеем статистику в HTML-файле, которую можно посмотреть через браузер.

Содержание  Вперед на стр. 028-080-2