« Поставить закладку » « Сделать стартовой »

« Форумы » « Блоги » « Статьи » « Новости » « Файлы » « Realcoding IRC » « Site map » « Поиск »


Главная Главная
Анонсы Анонсы
Форумы Форумы
Каталог Каталог
Поиск Поиск
Опросы Опросы
Книжный магазин Книжный магазин
Реклама на сайте
Публикации Публикации
Партнеры Партнеры
Карта Карта сайта
Рассылки Рассылки
RSS экспорт
Настройки Настройки
О нас пишут О нас пишут
Контакты Контакты
Гостевая книга Гостевая книга

Тестирование 64-битных приложений

ПнВтСрЧтПтСбВс
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30          
    Популярное
Многопоточные приложения для .NET

Потоки

Форма просмотра информации о клиентах на основе пользовательских классов

Трюк с курсором

Функция AccessResource

Math - математика, статистика, финансы. Краткий справочник по функциям в Delphi

Модель модифицированного микроядра

Приемы безопасного программирования веб-приложений на PHP

Введение в регулярные выражения. Синтаксис.

Типы




    Архив файлов



    Сообщества



    Документация

Статьи:: Интернет технологии :: PHP :: Триада PHP & MySQL & gd library Сервис счетчиков обращений


отправить ссылку другу версия для печати  Обсудить на форуме

Триада PHP & MySQL & gd library Сервис счетчиков обращений





Триада PHP

Триада PHP & MySQL & gd library Сервис счетчиков обращений

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

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

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

<img src="/scripts/counter.php3?SiteID=Vlad&PageID=About">

Здесь 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'

[an error occurred while processing this directive]

А теперь самое время вспомнить про префикс "_" значений 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 Countersn";
    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);




Рубрика: PHP




Google Developer Day 2008 в Москве.

Мероприятия

Дата проведения: 28 октября 2008 г.; Место проведения: Амбер Плаза, Москва, Россия. Конференция для веб-разработчиков и разработчиков мобильных приложений в Москве. Узнайте, как наилучшим образом использовать инструменты разработки и API от Google, чтобы создавать социальные, мобильные и картографические приложения, как использовать AJAX/JavaScript инструменты и библиотеки от Google и многое другое из первых уст.


Подробнее... | Рубрика: Мероприятия | Добавлено: 05.09.2008

ТОП 10 самых раздражающих факторов для программиста.

Разное

Совсем недавно наткнулся в интернете на забавный "хит-парад" наиболее раздражающих вещей для программиста. Поскольку он был на английском — решил перевести текст и несколько адаптировать к нашим реалиям…


Подробнее... | Рубрика: Разное | Добавлено: 03.09.2008

Windows Server 7, 8 и 9.

Windows Server 2003

К написанию этой статьи меня побудили недавние изыскания Мэри Джо Фоли (Mary Jo Foley) по поводу Windows 7 Server и Windows Server 2008 R2. Если бы не она, я, наверное, и не вспомнил бы о массе информации, имеющейся по этому поводу у меня. Если вы не слышали, Microsoft удалось смутить львиную долю пользователей своим заявлением о том, что Windows Server 2008 R2, чей релиз должен состояться в 2010 году, есть ничто иное, как Windows 7 Server.


Подробнее... | Рубрика: Windows Server 2003 | Добавлено: 03.09.2008

Остальные статьи:

jQuery для JavaScript-программистов
Инновационный веб-броузер Google Chrome стартует уже сегодня
Windows 7: подход к производительности системы
Trac + Subversion @ Ubuntu: Revisited
[g]Vim в режиме Python: Рекомпиляция в Windows
Java + JSON. Пути к дружбе
Драйвер SQL Server 2005 для PHP
Типы данных в MySQL (сжатый справочник для PHP программиста)
PHP класс для работы с Яндекс.XML
Ошибки начинающих PHP разработчиков
Наследование шаблонов в Smarty
Особенности хранения сессий PHP в memcached
Internet Explorer 8 beta 2
9 правил для начинающего Ajax-разработчика
ExtJS 2.2 - полная поддержка Firefox 3, новые виджеты и другие нововведения
Windows 7: под покровом тайны


Цитата дня (все,добавить):



    Рубрикатор

Программирование

C/С++
Обучение
Windows API
XAML
Моделирование
Паттерны
Visual Basic 7 .NET
WxWidgets
Функции WinApi
Функции С++
Разработка под Mac OS
Eiffel
Visual Studio 2008
UI дизайн
Алгоритмы
Конкурсные статьи
Turbo Pascal
Visual Studio
CASE-средства
Visual Studio 2005
Без VCL
Delphi
Тех. документация
Тестирование
Software Testing
ООП
TCP/IP
Google Android
Windows Installer
.NET Framework
Драйвера
C# C Sharp
Справка
Проектирование
Информ. системы
Visual Basic
Assembler
Оптимизация кода
Gtk+
Компоненты
Реинжиниринг
Управление проектами
Extreeme programming
Lotus Notes
Алгебраическое проектирование

Интернет технологии

PHP
Perl
ASP
WAP
Cookies
SSI
CGI
Web Servers
VB Script
DNS
CSS
XML
Html
Java Script
Java2ME
Firewall
Flash
.htaccess
Apache
VRML
Протоколы
Поисковые системы
Технология JAVA
Учебник по PHP
Учебник по JavaScript
Учебник по XML
Java Q&A
AJAX
DHTML
XHTML
Dreamweaver
Web 2.0
Python
Вебмастеру
Cisco
Ruby on Rails
Silverlight

Базы данных

Access
InterBase
MySQL
Oracle
ADO .NET
Основы SQL
Учебник по Access 2002
MS
Microsoft FoxPro
Доступ к данным
XML в MS SQL Server 2000
ODBC и MyODBC
Обучение
Caché
DB2
PostgresSQL
Sybase
Теория
Хранилища данных
Безопасность
Реляционные данные
MySQL и mSQL

Остальное:

Разное
Обзоры книг
Безопасность
Графика и дизайн
Юмор
Linux
Фракталы
Microsoft Axapta
Многоядерность
Сети
Microsoft Office
Работа
MS-DOS
Криптография
Графика и игроделание
Новости SDK
Системы защиты
Учебник по AutoCad
CVS
Windows XP
Windows Server 2003
Windows Vista
Windows 7
Мероприятия

    Кто на сайте
Вы не зарегистрированы.
Имя:

Пароль:

Запомнить

Регистрация позволит Вам пользоваться дополнительными сервисами.
Сейчас на сайте:
Гостей: 108
Пользователей: 0