Пользователь

Добро пожаловать,

Регистрация или входРегистрация или вход
Потеряли пароль?Потеряли пароль?

Ник:
Пароль:

Меню сайта




Ваше мнение
Какой браузер Вы предпочитаете?

Internet Explorer
Mozilla Firefox
Opera
Netscape
Chrome
Другой


Результаты
Другие опросы

Всего голосов: 1673
Комментарии: 10


Наши партнеры



Статистика




Programming books  Download software  Documentation  Scripts  Content Managment Systems(CMS)  Templates  Icon Sets  Articles  Contacts  Voting  Site Search




Статьи и обзоры



Анализ посещаемости сайта рефералами

Речь пойдет о новой версии самого популярного в настоящее время языка написания сценариев для сервера - РНР 5. Этот язык позволяет разрабатывать высокопроизводительные Web-сайты любого масштаба и любой категории сложности. Рассматриваются такие вопросы, как синтаксические конструкции языка, объектно-ориентированное программирование на РНР, работа с базами данных и графическими изображениями, а также построение WAP-содержимого. Большое внимание уделяется эффективным решениям типовых практических задач на PHP, среди которых аутентификация посетителей, шифрование данных, использование сеансов, обработка ошибок, работа с электронной почтой. Реферал - это url, с которого посетитель приходит на ваш сайт. К примеру, на странице http://www.site.com/links.html есть ссылка на ваш сайт. Если человек нажмет на нее, то он попадет на ваш сайт. Тогда url http://www.site.com/links.html будет вашим рефералом. Каждому владельцу ресурса не будет лишним знать, откуда именно заходят посетители на его сайт. Для тех, кому интересно решение данной проблемы (задачи) с помощью PHP, и посвящена данная статья.




Не спорю, что у любой уважающей себя CMS (content management system, система управления содержанием) есть модули (боты), которые отвечают за сбор статистики. Для тех же, у кого на сайте не стоит CMS, есть возможность попрактиковаться в написании и конфигурировании собственного мини-модуля статистики.

Его можно реализовать в небольшом скрипте, который будет отслеживать нажатия на ссылки, записывать их URL'ы в базу данных (в нашем примере это MySQL) и генерировать статистику в виде графика. Да и поможет разобраться, как это все работает на самом деле, не копаясь в модулях сторонних разработчиков.

Нам потребуется три файла:

* referer.sql (запрос к БД на создание таблицы, где будет храниться статистика);
* referer.php (сам скрипт);
* viewreferer.php (скрипт для просмотра статистики).

Для создания таблицы referer необходимо выполнить запрос referer.sql. Вот его содержание:

Код
CREATE TABLE referer (
url varchar(100) NOT NULL,
hits int(10) DEFAULT '0' NOT NULL,
PRIMARY KEY (url)
);


Теперь займемся файлом referer.php. Зададим значения переменным:

PHP - Код
$hostname "localhost"// предоставляется вашим хостером. 
//В большинстве случаев это - localhost (иногда бывает 127.0.0.1)
$username "your-username"// имя пользователя - ваш 
//логин для подключения к базе данных
$password "your-password"// вы должны получить его 
//у своего хостинг-провайдера
$userstable "referer"// таблица, в которой будут 
//храниться результаты работы нашего скрипта
$dbName "your-db-name"// имя БД, в которой 
//содержится таблица referer

.
.
.
.
.
.
.
.
.
.
.
.
В переменную $ref заносим информацию о ссылке-реферере:

PHP - Код
$ref strtolower($HTTP_REFERER);

.
.
С помощью функции strtolower переводим значение переменной $ref в нижний регистр. Это делается для того, чтобы ссылки типа www.site.com, www.Site.com или WWW.SITE.COM были одинакового регистра.

Если переменная $ref не пустая,

PHP - Код
if(!empty($ref)){

.
.
то подключаемся к БД:

PHP - Код
mysql_connect($hostname,$username$password) or die(mysql_error());
mysql_select_db("$dbName") or die(mysql_error());


Производим выборку из столбца url, значение которого совпадает с $ref

PHP - Код
$query "select * from $userstable where url = '$ref'";


Переменная $rows содержит количество совпадений

PHP - Код
$result mysql_query($query);
$rows mysql_num_rows($result);

.
.
.
Если же не найдено ни одной записи (т.е c такого url'a еще не было рефералов)

PHP - Код
if ($rows == 0){


устанавливаем значение переменной $hits в "1"

PHP - Код
$hits "1";

.
.
А далее просто выполняем вставку url'а и переменной $hits в нашу таблицу (referer):

PHP - Код
$query1 " into $userstable (url,hits) values('$ref','$hits')";


Выполняем запрос:

PHP - Код
mysql_query($query1);
}

.
.
.
Если же были найдены записи по данному url (т.е c этого url'a уже заходили рефералы),

PHP - Код
else {
$hitquery "select hits from $userstable where url = '$ref'";
$result2 mysql_query($hitquery);
$row mysql_fetch_array($result2);
$hits $row["hits"];


Инкрементируем значение переменной $hits (увеличиваем на "1")

PHP - Код
$query2 "update $userstable set hits = hits+1 where url = '$ref'";
mysql_query($query2);>
}
}

.
.
.
.
.
.
В ту страницу сайта, для которой необходима статистика по рефералам (как правило - это главная страница, index.php), необходимо вставить ссылку на скрипт referer.php. Предполагается, что файлы referer.php и index.php находятся в одной папке.

PHP - Код
include("referer.php");

.
.
.
На этом и заканчивается содержимое скрипта referer.php. Но, как я написал выше, есть также и графическая статистика. Это будет наш третий файл - viewreferer.php.

Задаем переменные для подключения к БД:

PHP - Код
$hostname "localhost";
$username "your-username";
$password "your-password";
$userstable "referer";
$dbName "your-db-name";

.
.
.
.
.
.
Так как этот скрипт генерирует таблицу с графиком, то есть смысл для определенных диапазонов значений хитов назначить определенные цвета.
PHP - Код
$color10 "#FFFF00";
$color20 "#FF0000";
$color50 "#008000";
$color1k "#0000FF";
$color2k "#0000A0";
$color5k "#000040";


Опять соединяемся с БД:
PHP - Код
mysql_connect($hostname$username,$password) or die(mysql_error());
mysql_select_db("$dbName") or die(mysql_error());


Делаем выборку из БД и упорядочиваем ее по убыванию (desc) количества хитов (столбец hits).
PHP - Код
$query "select * from $userstable order by hits desc";
$result mysql_query($query);


Подсчитываем количество строк с уникальными рефералами (это попросту число строк в нашей таблице referer).
PHP - Код
$number mysql_num_rows($result) or die (mysql_error());
$i 0;

.
.
.
Если же не найдено ни одной записи (таблица пуста), то выводим сообщение:
PHP - Код
if ($number == 0) {
echo 
"<center><p><b>Сведений о рефералах не обнаружено!</b></center>";
}

Если же рефералы есть:
elseif (
$number >= 1) {
while (
$i $number){
$row mysql_fetch_array($result);
$hits $row["hits"];
$ref $row["url"];


Выбираем цвет для текущего значения hits:
PHP - Код
if ($hits <10){
$color "$color10";
}
elseif ((
$hits >= 10 )
and (
$hits 20)){
$color "$color20";
}
elseif ((
$hits >= 20 )
and (
$hits 50)){
$color "$color50";
}
elseif ((
$hits >= 50 )
and (
$hits 100)){
$color "$color1k";
}
elseif ((
$hits >= 100 )
and (
$hits 200)){
$color "$color2k";
}
elseif (
$hits >= 200){
$color "$color5k";
}


Табличка с графиком строится как результат MySQL-запроса. В первой колонке содержится название url'а, а во второй - количество хитов, а в третей - цветная полоса.
PHP - Код
echo "<div align="left">";
echo 
"<table cols=3 border="0" width="100%">
<tr><td align=left width="
400"><b>
<a href="
$ref">$ref</a></b></td>";
echo 
"<td align=right width="60"><b>$hits</b></td>";
echo 
"<td align=left width="$hits" bgcolor="$color"> </td></tr>";
$i++;
echo 
"</table>n";
}
}

.
.
.
.
.
.
.
.
.
.
.
Итак, все готово! Теперь можно периодически вызывать скрипт viewreferer.php и смотреть графическую статистику переходов на ваш сайт.



Нет комментариев. Почему бы Вам не оставить свой?
Вы не можете отправить комментарий анонимно, пожалуйста войдите или зарегистрируйтесь.
Внимание! Если у вас не получилось найти нужную информацию, используйте рубрикатор или воспользуйтесь поиском


.



Статьи и обзоры PHP Анализ посещаемости сайта рефералами Реферал это которого посетитель приходит на ваш сайт примеру странице http //www site com/links html есть ссылка Если человек нажмет нее то он попадет Тогда будет вашим рефералом Каждому владельцу ресурса не лишним знать откуда именно заходят посетители его Для тех кому интересно решение данной проблемы задачи помощью посвящена данная статья Не спорю что любой уважающей себя content management system система управления