Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
Имитационное мо... 59419
Реклама
Сейчас на сайте
Гостей: 7
На сайте нет зарегистрированных пользователей

Пользователей: 13,109
новичок: syqwe
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Принадлежит ли точка пересечению двух окружностей на Turbo Pascal + Отче...
Моделирование работы обрабатывающего участка цеха в GPSS
Калькулятор на Delphi с переводом в другую систему исчисления + Блок схемы

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Триада PHP - MySQL - GD
Триада PHP & MySQL & gd library - Сервис счетчиков обращений

Статья не совсем свежая, но вполне актуальная, за исключением одного «но». Библиотека GD теперь не имеет возможности создавать GIF картинки, зато отлично создает более компактные PNG.
Гойда Владимир

Php - (Hypertext Preprocessor) - платформо-независимый язык для динамического наполнения WEB-сайта. Тем неменее, он позволяет динамически генерировать не только HTML-документы, но и графические изображения в формате gif. В статье рассмотрены вопросы обработки параметров get-запроса, доступа к базе MySQL и генерации gif-рисунков на практическом примере.

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

Как это работает? Web-мастер помещает на свою страницу ссылку на рисунок. Но не gif или jpeg, а на этот php скрипт. Положим, ссылка на счетчик страницы 'Об авторе', расположенной на моем сайте будет выглядеть так:


Здесь SiteID и PageID - так называемые get-параметры, а Vlad и About - их значения. Эти get-параметры идентифицируют счетчик. Скрипт найдет соответсвующую запись в базе, увеличит значение счетчика на еденицу и построит рисунок. Пример картинки, как выглядит счетчик:
Внешний вид счетчика

Мы еще не представляем как будет выглядеть все остальное но уже можем обработать get-параметры
$locSiteID = $HTTP_GET_VARS["SiteID"];
$locPageID = $HTTP_GET_VARS["PageID"];

Здесь следует остановиться на важном моменте. Дело в том, что по правилам php имена переменных и get-параметров чувствительны к регистру. Это значит, что если человек напишет ссылку и get-параметры прописными буквами, то наш скрипт не сможет распознать такой запрос. Поэтому я предлагаю не такой изящный, но очень надежный способ интерпреции get-параметров. Состоит он вот в чем: последоватьным перебором всех get-параметров попытаемся найти интересующие нас SiteID и PageID. Причем при поиске используем нечувствительное к регистру сравнение строк:
$locSiteID = "_";
$locPageID = "_";
while (list($key, $val) = each($HTTP_GET_VARS))
{
if (strcmp(strtoupper($key),"SITEID")==0) $locSiteID = "_" . $val;
if (strcmp(strtoupper($key),"PAGEID")==0) $locPageID = "_" . $val;
}

Здесь префикс "_" необходим для MySQL-движка. Далее установим базу счетчиков Counters
mysqladmin create Counters

и создадим в ней таблицу Counters. Таблица как вы наверно уже догадались, состоит из трех полей: SiteID, PageID, CountValue:
Create Table Counters (
SiteID char(120) not null,
PageID char(120) not null,
CountValue int,
index CounterIndex (SiteID,PageID));

Обратите внимание на индекс CounterIndex. Поля, входящие в индекс, должны иметь атрибут NOT NULL, размер ключей (читай полей, входящих в индекс) не должен превышать 256 символов. И последнее - порядок полей в индексе должен совпадать с порядком в секции Where SQL запроса. Если же Вы планируете небольшую базу и колчество записей невелико, то индекс можно и не создавать.

Для работы с базой нам потребуется всего три запроса:
Создать новую запись в базе при первом обращении к счетчику:
INSERT INTO counters (SiteID,PageID,CountValue)
VALUES ('$locSiteID','$locPageID',1)
Найти значение счетчика:
SELECT * FROM counters WHERE SiteID='$locSiteID' AND PageID='$locPageID'
Увеличить значение счетчика на еденицу:
UPDATE counters SET CountValue = CountValue+1
WHERE SiteID = '$locSiteID' AND PageID = '$locPageID'

А теперь самое время вспомнить про префикс "_" значений get-параметров. На самом деле все очень просто. Посмотрите на структуру таблицы. Поля SiteID, PageID помечены аттрибутом NOT NULL, и префикс "_" позволяет пропустить один или даже оба параметра в get-запросе:
// Нечувствительные к регистру get-параметры
$locSiteID = "_";
$locPageID = "_";
while (list($key, $val) = each($HTTP_GET_VARS))
{
if (strcmp(strtoupper($key),"SITEID")==0) $locSiteID = "_" . $val;
if (strcmp(strtoupper($key),"PAGEID")==0) $locPageID = "_" . $val;
}

// Соеденяемся с базой Counters и запрашиваем значение счетчика
mysql_connect("localhost:3306","root","");
if (!($result = mysql_db_query("Counters","select * from counters
where SiteID='$locSiteID' AND PageID='$locPageID'")))
{
// База Counters не доступна - катапультируемся
echo "Cannot query database Counters\n";
echo "Query Error " . mysql_errno() . " " . mysql_error();
exit;
}

$FirstVisit=1;
while($row = mysql_fetch_object($result))
{
$FirstVisit=0;
$locCountValue = $row->CountValue;
}
mysql_free_result($result);

if ($FirstVisit==1)
{ // Первое обращение. Создаем запись в базе
$result = mysql_db_query("Counters","Insert Into Counters
(SiteID,PageID,CountValue) Values ('$locSiteID','$locPageID',1)");
$locCountValue = 1;
}
else
{ // Увеличиваем значение счетчика на еденицу
$locCountValue = $locCountValue + 1;
$result = mysql_db_query("Counters","Update Counters Set
CountValue = CountValue+1 Where SiteID = '$locSiteID'
AND PageID = '$locPageID'");
}

Преобразовываем число в строку и форматируем в шестизначное число.
$strCounterValue = sprintf("%d",$locCountValue);
while(strlen($strCounterValue)<6) $strCounterValue = "0" . $strCounterValue;
$txtlen = strlen($strCounterValue);

Далее показано как пользоваться gd library в php для динамического рисования счетчика. Строго говоря, это не самый иллюстративный пример. Шрифты, входящие в библиотеку gd library могут различаться по дистрибутивам, поэтому для этого проекта я использовал спецальный формат представления шрифта и процедуру его отображения. Тем неменее код достаточно документирован и, я надеюсь, поможет вам сделать очередной шаг.
Header("Content-type: image/gif");
$DeskWidth=24; $DeskHeight=48; $DeskSpace=5;

/* Создаем рисунок imgWidth * imgHeight pixels. */
$imgWidth= $txtlen * ($DeskWidth + $DeskSpace) - $DeskSpace;
$imgHeight = $DeskHeight;
$im_out = ImageCreate($imgWidth, $imgHeight);

/* Резервируем цвета в палитре*/
$white = ImageColorAllocate($im_out, 255, 255, 255);
$grey = ImageColorAllocate($im_out, 0, 0, 77);
$blue = ImageColorAllocate($im_out, 40, 5, 250);
$trans = ImageColorAllocate($im_out, 1, 1, 1);
$red = ImageColorAllocate($im_out, 40, 33, 155);

/* Устанавливаем прозрачный цвет и рисуем фон*/
ImageColorTransparent($im_out, $trans);
for ($dy=0; $dy < $imgHeight; $dy++)
ImageLine($im_out, 0, $dy, $imgWidth-1, $dy, $trans);
for ($dy=2; $dy < $imgHeight; $dy=$dy+4)
ImageLine($im_out,0,$dy,$imgWidth-1,$dy,$red);

// Далее выводим цифры по пикселам,
// сначала "тень" со смещением в один пиксел а поверх и "лицо"
$CurColor=$white;
for ($txtcur=0;$txtcur<$txtlen;$txtcur++)
{
$bx=$txtcur*($DeskWidth+$DeskSpace);
for ($dy=0;$dy<$imgHeight;$dy++)
ImageLine($im_out,$bx,$dy,$bx+$DeskWidth-1,$dy,$blue);
$bx=$bx+($DeskWidth-22)/2;
$c=0+$strCounterValue[$txtcur];
if ($c!=0) $CurColor=$white;
if (($c>=0) && ($c<=9))
for ($id=1;$id>=0;$id--)
{
if ($id==1) $CurColor=$grey; else $CurColor=$white;
for ($dy=0;$dy<48;$dy++)
for ($dx=0;$dx<22;$dx++)
{
$my_pos = $c*48*3 + $dy*3 + ($dx>>3);
$my_byte = $CounterDigitData[$my_pos];
if ((($my_byte >> (7-($dx & 7))) & 1) == 1)
ImageSetPixel($im_out,$bx+$dx+$id-1, $dy+$id, $CurColor);
}
}
}

// Отправляем обозревателю картинку ...
ImageGif($im_out);
// ... и освобождаем память
ImageDestroy($im_out);
Опубликовал Kest November 02 2008 17:28:01 · 0 Комментариев · 6203 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Архив программ
Библия хакера 2. ...
Импорт новостей ...
Разработка клиент...
Просмотр файлов и...
RbControls
Иллюстрированный ...
Алгоритм DES шифр...
Библия для програ...
PHP5. Профессиона...
Delphi 2005 Учимс...
Искусство програм...
Blobs [Исходник н...
Пример работы с б...
База игр
Библия хакера 2 К...
EditButton
TMS
БД студентов
IpEditAdress

Топ загрузок
Приложение Клие... 100512
Delphi 7 Enterp... 90199
Converter AMR<-... 20092
GPSS World Stud... 14945
Borland C++Buil... 12690
Borland Delphi ... 8936
Turbo Pascal fo... 7093
Калькулятор [Ис... 5126
Visual Studio 2... 5018
FreeSMS v1.3.1 3554
Случайные статьи
Стандарт IEEE 802....
Программный продукт
Инструменты ДЛЯ по...
Видео-покер и казино
Функция TextWidth ...
true
Варианты ошибок с ...
INDEX (ИНДЕКСИРОВАТЬ)
Упорядочить по воз...
машина Поста на C#...
Квартира в Новой У...
Фотоаппарат и всп...
Кроме того, устано...
Directory и объект...
• Computer (Компью...
Установка соединен...
Сортировка каталог...
Пишем программу мо...
Потребность в глоб...
В перспективе VRML
Неоднозначность ключа
setDisplay
OpenGL. МИНИМАЛЬНА...
Использование датч...
Mill Trade (доход ...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?