Пособие по
РНР-программированию.
Часть 1.
Источник: рассылка
сайта http://dweb.ru
HTTP-аутификация средствами PHP
HTTP аутификация в PHP доступна только при использовании модуля Apache. В модуле Apache PHP-скрипт, может использовать функцию Header() для отправки сообщения "Authentication Required" браузеру клиента, вызвав тем самым окно диалога Username/Password. Как только пользователь заполняет поля username и password, URL содержащий PHP-скрипт будет вызван заново с переменными $PHP_AUTH_USER, $PHP_AUTH_PW и $PHP_AUTH_TYPE содержащими введенную информацию. В данном случае обеспечивается только "Основная" аутификация.
Фрагмент примера сценария, который производит аутентификацию клиента на странице, должен быть следующим:
Пример 2-1. Пример HTTP аутификации
<?php if(!isset($PHP_AUTH_USER)) { Header("WWW-Authenticate: Basic realm=\"My Realm\""); Header("HTTP/1.0 401 Unauthorized"); echo "Text to send if user hits Cancel button\n"; exit; } else { echo "Hello $PHP_AUTH_USER.<P>"; echo "You entered $PHP_AUTH_PW as your password.<P>"; } ?>
Вместо просто распечатывания $PHP_AUTH_USER и $PHP_AUTH_PW, Вы вероятно хотели бы проверить имя_пользователя и пароль для проверки правильности. Возможно, посылая запрос к базе данных, или, ища пользователя в dbm файле.
Будьте внимательны при использовании браузера Internet Explorer. Он весьма придирчив к порядку заголовков. Отправка заголовка WWW-Authenticate перед заголовком HTTP/1.0 401 возможно даст аутификацию в любом случае.
Чтобы предотвратить от записи кем - то сценарий , который определяет пароль для страницы, которая была опознана через традиционный внешний механизм, PHP_AUTH переменные не будут установлены, если допускается внешнее установление подлинности для той специфической страницы. В этом случае может быть использована переменная $REMOTE_USER чтобы идентифицировать внешне-опознанного пользователя.
Обратите внимание, однако, что вышеупомянутое не защищает от кого - то, кто может управлять не-аутифицированным URL используя перехваченный пароль из аутифицированных URL на том же самом сервере.
И Netscape и Internet Explorer очистит локальный кэш окна аутификации после получения ответа сервера 401. Это эффективно как мера отключения пользователей("log out"), вынуждающая их повторно ввести их username и пароль. Некоторые используют это для отключения пользователя по истечении интервала времени("time out"), или обеспечивают кнопку "Log Out".
Эти методы не требуются в соответствии с Основным стандартом аутификации HTTP , так что Вы никогда не должны зависеть от этого. Тестирование с Lynx показало, что Lynx не очищает информацию аутификации с 401 ответом сервера, так что переход обратно и затем вперед снова откроет ресурс (пока требования удостоверения личности не изменились).
Также обратите внимание, что это не работает при использовании сервера Microsoft's IIS и CGI версии PHP из-за ограничений IIS.
Создание GIF-файлов
с помощью PHP.
PHP не ограничен созданием только HTML вывода. Он
может также использоваться для создания файлов
GIF, или даже более удобные потоки изображений GIF.
Для этого вам надо скомпилировать PHP с
библиотекой функций изображения - GD .
Пример 2-2. Создание GIF-файлов с помощью PHP
<?php Header("Content-type: image/gif"); $string=implode($argv," "); $im = imagecreatefromgif("images/button1.gif"); $orange = ImageColorAllocate($im, 220, 210, 60); $px = (imagesx($im)-7.5*strlen($string))/2; ImageString($im,3,$px,9,$string,$orange); ImageGif($im); ImageDestroy($im); ?>
Этот пример вызывается со страницы тегом: <img src="button.php3?text"> Вышеупомянутый скрипт button.php3 берет строку "text", накладывает сверху на основное изображение, которым в этом случае является " images/button1.gif " и выводит возникающее в результате изображение. Это - очень удобный способ не рисовать новые изображения кнопки, каждый раз, когда вы хотите изменить текст кнопки. Этим методом они будут динамически сгенерированы.
Поддержка file upload.
PHP может принимать файлы,
загруженные из любого браузера, отвечающего
стандартам RFC-1867 (которыми являются, например,
Netscape Navigator 3 или cтарше, Microsoft Internet Explorer 3 с
исправлениями от Microsoft, или cтарше). Эта
возможность позволяет людям загружать файлы. С
PHP-аутификацией и функциями манипулирования
файлами, вы имеете полный контроль над тем, кому
позволять загружать файлы и что должно быть
выполнено с файлом, если он был загружен.
Экран загрузки файла может быть организован
созданием специальной формы, которая выглядит
примерно так:
Форма загрузки файла
<FORM ENCTYPE="multipart/form-data" ACTION="_URL_" METHOD=POST>
<INPUT TYPE="hidden" name="MAX_FILE_SIZE"
value="1000">
Send this file: <INPUT NAME="userfile" TYPE="file">
<INPUT TYPE="submit" VALUE="Send File">
</FORM>
_URL_ должен указать на php html файл. Cкрытое поле
MAX_FILE_SIZE должно предшествовать полю ввода файла и
означает максимально допустимый размер файла.
Значение определяется в байтах. Для этого файла
при успешной загрузке будут определены
следующие переменные :
$userfile - Временное имя файла под которым
загруженный файл загружается в машину сервера.
$userfile_name - Исходное имя файла в системе
отправителя.
$userfile_size - Размер загруженного файла в байтах.
$userfile_type - Тип MIME файла, если броузер
предоставил эту информацию.
Например может быть "image/gif".
Обратите внимание, что компонент вышеупомянутых
переменных "$userfile" - это любое значение
поля Name тега INPUT c TYPE=file обозначенное в форме
загрузки. В приведенном выше примере формы
загрузки мы назвали его "userfile".
По умолчанию файлы будут сохранены в заданном по
умолчанию временном каталоге сервера. Его можно
изменить, установкой переменной среды TMPDIR в
среде, в которой PHP выполняется. Хотя,
использование при ее установке обращения PutEnv ()
изнутри сценария PHP не будет работать.
Скрипт PHP, который получает загруженный файл,
должен определить, что должно быть выполнено с
загруженным файлом. Вы можете, например,
использовать переменную $file_size, чтобы
отбросить любые файлы, которые являются или
слишком маленькими или слишком большими. Вы
могли бы использовать переменную $file_type,
чтобы отбросить любые файлы, которые не
соответствуют некоторым критериям типа. В любом
случае, вы должны или удалить файл из временного
каталога или переместить эго в другое место.
Файл будет удален из временного каталога в конце
запроса, если он не перемещен или переименован.
Пожалуйста обратите внимание, что вебсервер CERN
httpd, кажется, удаляет все начинающееся с первого
пробела в заголовке content-type mime, полученном от
клиента. Пока дело обстоит так, CERN httpd не будет
поддерживать возможность загрузки файла.
Поддержка HTTP cookie.
PHP поддерживает HTTP cookies. Cookies -
механизм для сохранения данных в удаленном
браузере и, таким образом, - трэкинг или
идентификация пользователей. Вы можете
устанавливать файлы cookie используя функцию
setcookie(). Cookies - часть HTTP заголовка, так что функция
SetCookie() должна вызваться прежде чем браузеру
послан какая-нибудь информация для вывода. Это -
то же самое ограничение, которое касается и
функции Header().
Любой cookie, посланный Вам от клиента будет
автоматически превращен в переменную PHP точно
так же как данные методов GET и POST. Если вы желаете
назначить множественные значения одиночному cookie
- просто добавьте [] к имени cookie. Для более
подробной информации см. функцию setcookie ().
Поддержка
баз данных
PHP поддерживает ряд различных баз данных, и в режиме работы в собственной системе команд и через ODBC, включая:
Adabas D MySQL dBase Oracle Empress PostgreSQL FilePro Solid Informix Sybase InterBase Velocis mSQL Unix dbm
Регулярные выражения
Регулярные выражения
используются для сложного манипулирования
строками в PHP. Функции, которые поддерживают
регулярные выражения:
ereg() ereg_replace() eregi() eregi_replace() split()
Все эти функции принимают строку регулярного выражения как их первый параметр. PHP использует расширенные регулярные выражения POSIX как определено в POSIX 1003.2. Для полного описания регулярных выражений POSIX см. соответствующие разделы руководства (regex), в каталоге regex дистрибутива PHP.
Example 2-4. Пример регулярных выражений
ereg("abc",$string); /* Возвращает 'истина', если "abc" найдено в строке $string. */ ereg("^abc",$string); /* Возвращает 'истина', если "abc" найдено в начале строки $string. */ ereg("abc$",$string); /* Возвращает 'истина', если "abc" найдено в конце строки $string. */ eregi("(ozilla.[23]|MSIE.3)",$HTTP_USER_AGENT); /* Возвращает 'истина', если браузер клиента - Netscape 2, 3 или MSIE 3. */ ereg("([[:alnum:]]+) ([[:alnum:]]+) ([[:alnum:]]+)", $string,$regs); /* Помещает три слова - $regs[1], $regs[2] и $regs[3], разделенные пробелом. */ ereg_replace("^","<BR>",$string); /* Устанавливает тег <BR> в начало строки $string. */ ereg_replace("$","<BR>",$string); /* Устанавливает тег <BR> в конец строки $string. */ ereg_replace("\n","",$string); /* Отсекает символ "возврат каретки" в строке $string. */
Обработка ошибок
В PHP есть 4 типа ошибок и предупреждений. Это:
1 - Нормальные Ошибки Функции(Normal Function Errors) 2 - Нормальные Предупреждения(Normal Warnings) 4 - Ошибки Синтаксического Анализатора(Parser Errors) 8 - Уведомления(Notices) : предупреждения, которые Вы можете проигнорировать но, которые могут подразумевать баги в вашем коде
Эти 4 типа комбинируются при определении ошибки, сообщая уровень. Ошибка по умолчанию, возвращает уровень 7, который является комбинацией 1 + 2 + 4, или все ошибки за исключением примечаний. Этот уровень может быть изменен в файле php3. ini директивой error_reporting. Он также может быть установлен в вашем файле Apache httpd.conf директивой php3_error_reporting, или же это может быть произведено во времени выполнения сценария, с использованием функции error_reporting ().
Руководство по
установке PHP3 для Windows.
Это руководство по установке поможет
Вам установить и сконфигурировать PHP3 на Ваших web
серверах под Windows 9x/NT. Данное руководство
составил Bob Silva.
Последнюю версию можно найти по адресу http://www.umesd.k12.or.us/php/win32install.html.
Данное руководство обеспечивает поддержку установки на:
Personal Web Server (рекомендуется новейшая версия) |
Internet Information Server 3 or 4 |
Apache 1.3.x |
Omni HTTPd 2.0b1 |
Изменение конфигурации для PHP3:
Все модули теперь начинаются с префикса 'php3_'. Вы должны изменить свой файл php3.ini и/или все сценарии загрузки расширений с функцией dl() (либо везде удалите префикс 'php3_'). Это предотвратит путаницу между модулями PHP и их библиотеками обеспечения.
ChangeLog, FAQ и обновленную документацию всегда можно найти на официальном сайте PHP или любом из его зеркал.
Данные шаги должны быть выполнены при любой установке перед специфическими инструкциями сервера:
c:\windows for Windows 95/98 |
c:\winnt or c:\winnt40 for NT servers |
Руководство по установке PHP3 для Windows 95/98/NT и PWS/IIS 3.
Рекомендуемый метод
конфигурирования этих серверов состоит в
использовании INF файлов, поставляемых с
дистрибутивом (php_iis_reg.inf). Вы можете
отредактировать этот файл и убедитесь, что
расширения и установочная директория PHP
соответствует Вашим параметрам. Или Вы можете
следовать перечисленным ниже шагам, чтобы
сделать это вручную.
ПРЕДУПРЕЖДЕНИЕ: Эти шаги включают в себя
непосредственную работу с windows registry. Мы
настоятельно рекомендуем вам сначала сделать
резервную копию registry. Группа разработчиков PHP не
несет ответственности, если Вы повредите Ваш
registry.
Пользователи PWS и IIS 3
теперь имеют полностью работающую систему.
Пользователи IIS 3 могут использовать tool от Steven Genusa
для конфигурирования своих карт сценариев.
Константа.
PHP определяет несколько констант и предоставляет механизм для определения Ваших констант. Константы похожи на переменные, но они имеют слегка измен©нный синтаксис.
Предопредел©нные константы - это __FILE__ and __LINE__, которые соответствуют имени файла и номеру строки, которая выполняется в настоящий момент.
Пример 6-1.
Использование __FILE__ и __LINE__<?php function report_error($file, $line, $message) { echo "An error occured in $file on line $line: $message."; } report_error(__FILE__,__LINE__, "Something went wrong!"); ?> |
Вы можете определить
дополнительные константы с помощью функций define()
и undefine() .
Пример 6-2. Описание
констант<?php define("CONSTANT", "Hello world."); echo CONSTANT; // outputs "Hello world." undefine ("CONSTANT"); ?> |
function foo () { return 5; }
Подразумевая, что вы
знакомы с концепциями функции (если нет,
взгляните на часть, посвящЈнную функциям), вы
считаете, что $c = foo() это практически то же самое,
что написать $c = 5 и вы правы. Функции - это
выражения с тем значением, которое они
возвращают. Так как foo() возвращает 5, значение
выражение 'foo()' - 5. Обычно функции подсчитывают
возвращаемое значение,а не возвращают
постоянное значение.
Конечно, значения в PHP не обязаны быть целыми и
зачастую они не являются таковыми. PHP
поддерживает 3 скалярных типа значений : целое,
число с плавающей точкой и строки ( скалярные
выражения вы не можете "разбить" на более
маленькие части, как, к примеру, массивы). PHP
поддерживает 2 составных (нескалярных) типа :
массивы и объекты. Каждое из таких значений может
быть присвоено переменной или возвращено
функцией.
Итак, пользователи PHP/FI 2 не должны почувствовать
каких-то перемен. PHP это язык, ориентированный на
выражения, практически всЈ является
выражениями.Обратимся к примеру, с которым мы уже
разобрались, '$a = 5'. Легко заметить, что тут
задействованы два значения - значение целой
константы 5 и значение $a, которое также
становиться равным 5.На самом деле здесь
присутствует ещЈ одно значение, значение самого
присваивания. Само присваивание становиться
равным присваиваемому значению, в данном случае -
5.На практике это означает, что '$a = 5', не обращая
внимания на то, что оно равно выражению со
значением 5. То есть, запись типа '$b = ($a = 5)' похожа
на запись'$a = 5; $b = 5;' (точка с запятой отмечает
конец выражения). Так как присваивания
рассматриваются справа налево, вы также можете
написать '$b = $a = 5'.
Другой хороший пример направления выражения это
прежварительное и последующее увеличение и
уменьшение. Рользователи PHP/FI 2 и многих других
языков могут быть знакомы с записями variable++ and
variable--. Это операторы увеличения и уменьшения. В
PHP/FI 2, оператор '$a++' не имеет значения(не является
выражением), поэтому вы не можете его присвоить
или использовать как-либо иначе. PHP расширяет
возможность увеличения/уменьшения делая его
выражением, как и в C. В PHP, подобно C, есть 2 типа
инкремента - предварительный и последующий. И
предыдущий и последующий инкремент увеличивает
значение переменной и воздействие на переменную
идентично.Разница в значении выражения
инкремента. Предыдущее увеличение, которое
записывается как '++$variable', приравнивается
увеличенной переменной (PHP увеличивает
переменную до того, как прочитать ее значение).
Post-increment, which is written '$variable++' evaluates to the original value of
$variable, before it was incremented (PHP increments the variable after reading its value,
thus the name 'post-increment').
Очень распространЈнный тип выражений это
выражения сравнения. Эти выражения имеют
значение 0 или 1 (означает ложь или истину
соответственно). PHP поддерживает > (больше, чем),
>= ( больше или равно), = (равно), < (меньше,чем) и
<= (меньше или равно). Эти выражения в основном
используются внутри условий, например оператора
IF.
Последний пример выражений, с которыми мы
разберЈмся, это совмещенные выражения
оператор-присваивание. Вы уже знаете, что для
того, чтобы увеличить значение $a на еденицу, вы
можете написать '$a++' или '++$a'. Но если следует
увеличить значение больше, чем на еденицу, к
примеру - на 3? Вы можете написать '$a++' несколько
раз, но это не очень удобно и эффективно. Намного
больше распространено написание '$a = $a + 3'. '$a + 3'
вычисляется, как значение $a плюс 3, а затем
присваивается переменной $a, в результате чего
значение $a увеличивается на 3. В PHP, также как и в
ряде других языков типа C, вы можете записать это
короче, что со временем бывает проще и быстрее
также и для понимания. Добавление 3 к текущему
значению $a может быть записано как '$a+=3'. Это
значит следующее : 'возьми значение $a, добавь к
нему 3 и присвой это обратно $a. Кроме того, что это
быстрее и понятнее, такой тип выражений быстрее
исполняется. Значение '$a+=3' как и значение
обычного присваивания это присвоенное значение.
Заметьте, что оно не равно 3, а является общим
значением $a и 3. Любой бинарный (имеющий 2 операнда
- прим. пер.) оператор может быть записан таким
методом, например : '$a-=5' (вычесть 5 из значения $a),
'$b*=7' (умножиить значение $a на 7) и так далее.
Есть еще такое выражение, которое может
показаться незнакомым, если вы не встречались с
ним в других языках - условный оператор с тремя
операндами :
$first ? $second : $third
Если значение первого выражения истинно (не
равно 0), то испольняется второе выражение и это
является результатом данного условного
выражения. Иначе исполняется третий оператор.
Этот пример должен помочь Вам лучше понять
предварительное и последующее увеличение и
вообще выражения ?
function double($i) /* функция удваивания
переменной */
{
return $i*2;
}
$b = $a = 5; /* присваиваем значения
переменым $a и $b */
$c = $a++; /* последующее увеличение,
присваиваем $c начальное значение $a (5)*/
$e = $d = ++$b; /* предварительное увеличение,
присваиваем $d и $e увеличенное значение$b (6) */
/* тут и $d и$e равны6 */
$f = double($d++); /* присвоить удвоенное
значение $d до его увеличения, то есть 2*6 = 12,
переменной $f*/
$g = double(++$e); /* присвоить удвоенное
значение $e после его увеличения, то есть 2*7 = 14,
переменной g */
$h = $g += 10; /* сначала увеличить значение $g
на 10, что дает в результате 24, а затем присвоить
это значение переменной $h, что также дает 24 */
В начале главы мы сказали, что объясним различные
типы операторов и, как и было обещано выражения
могут быть операторами. Впрочем, не каждое
выражения является оператором. В данном случае
оператор имеет форму 'выражение' ';', то есть
выражение, за которым следует точка с запятой. В
'$b=$a=5;' $a=5 это правильное выражение, но само по
себе оно не является оператором. А вот '$b=$a=5;'
является правильным оператором.
Еще одна вещь, которую нужно упомянуть - это
логические значения выражений. Во многих
случаях, в основном в условных операторах и
операторах циклов, вы не заинтересованы в
конкретных значениях выражений, а только
являются ли их значения TRUE или FALSE (в PHP нет
специального типа boolean). Логические значения
вычисляются примерно так же, как я в языке Perl.
Любое не нулевое целое значение - это TRUE, ноль -
это FALSE. Обратите внимание на то, что
отрицательные значения - это не ноль и поэтому
они считаются равными TRUE. Пустая строка и строка
'0' это FALSE; все остальные строки - TRUE. И насчет
составных типов (массивы и объекты) - если
значение такого типа не содержит элементов, то
оно считается равным FALSE; иначе подразумевается
TRUE.
PHP предоставляет полную и мощную реализацию
выражений и подробное еЈ описание выходит за
пределы этого руководства. ПриведЈнные выше
примеры показали вам, что такое выражения и как
вы можете построить реальные выражения. В
остальной части руководства мы будем писать 'expr'
для обозначения любого правильного выражения PHP.
if (expr) statement
Как объяснялось в части про выражения, вычисляется логический результат "expr". Если expr равно TRUE, то PHP выполнит "statement", а если FALSE - проигнорирует.
Следующий пример выведет фразу 'a is bigger than b' если $a больше $b:
if ($a > $b)
print "a is bigger than b";
Зачастую Вам требуется исполнить больше чем одно выражение по условию. Конечно, не надо окружать каждое выражение конструкцией IF. Вместо этого вы можете сгруппировать несколько выражений в блок выражений. К примеру, слежующий код не только выведет фразу, но и присвоит значение $a переменной $b:
if ($a > $b) { print "a is bigger than b"; $b = $a; }
Выражение IF может иметь неограниченную степень вложенности в другие выражения IF, что позволяет Вам эффективно использовать выполнение по условию различных частей программы.
ELSE
Зачастую Вам требуется исполнить одно выражение, если соблюдается какое-либо условие и другое выражение в противном случае. Вот для этого применияется ELSE. ELSE расширяет возможности IF по части обработки вариантов выражения, когда оно равно FALSE. Данный пример выведет фразу 'a is bigger than b' если $a больше $b, и 'a is NOT bigger than b' в противном случае:
if ($a > $b) { print "a is bigger than b"; } else { print "a is NOT bigger than b"; }
Выражение ELSE выполняется только если выражение IF равно FALSE, а если есть конструкции ELSEIF - то если и они также равны FALSE (см. ниже).
ELSEIF
ELSEIF, как и следует из его названия, является комбинацией IF и ELSE. ELSEIF как и ELSE позволяет выполнить выражение, если значение IF равно FALSE, но в отличие от ELSE оно выполнится только если выражение ELSEIF равно TRUE.К примеру, следующий код выведет 'a is bigger than b' если$a>$b, 'a is equal to b' если $a==$b, и 'a is smaller than b' если$a<$b:
if ($a > $b) { print "a is bigger than b"; } elseif ($a == $b) { print "a is equal to b"; } else { print "a is smaller than b"; }
Внутри одного выражения IF может быть несколько ELSEIF. Первое выражение ELSEIF (если таковые есть), которое будет равно TRUE, будет выполнено. В PHP3 вы можете написать 'else if' (два слова), что будет значить то же самое, что и 'elseif' (одно слово).
Выражение ELSEIF будет выполнено только если выражение IF и все предыдущие ELSEIF равно FALSE, а данный ELSEIF равен TRUE.
Иной
синтаксис для оператора IF : IF(): ... ENDIF;
PHP3 предлагает иной путь для группирования
операторов с оператором IF. Наиболее часто это
используется когда вы внедряете блоки HTML внутрь
оператора IF, но вообще может использоваться где
угодно. Вместо использования фигурных скобок за
"IF(выражение)" должно следовать двоеточие,
одно или несколько выражений и завершающий ENDIF.
Рассмотрите слежующий пример :
<?php if ($a==5): ?> A = 5 <?php endif; ?>
В этом примере блок "A = 5" внедрЈн внутрь выражения IF, используемого альтернативным способом. Блок HTML будет виден только если $a равно 5.statement written in the alternative syntax.
Этот альтернативный синтаксис применим и к ELSE и ELSEIF (expr) .Вот пример подобной структуры :
if ($a == 5): print "a equals 5"; print "..."; elseif ($a == 6): print "a equals 6"; print "!!!"; else: print "a is neither 5 nor 6"; endif;
WHILE
Цикл WHILE - простейший тип цикла в PHP3. Он действует
как и его аналог в C. Основная форма оператора WHILE :
WHILE(expr) statement
Смысл оператора WHILE прост. Он предписывает PHP выполнять вложенный(е) оператор(ы) до тех пор пока expr равно TRUE. Значение выражения проверяется каждый раз при начале цикла, так что если значение выражения изменится внутри цикла, то он не прервется до конца текущей итерации (выполнение всего блока вложенных операторов - это одна итерация). Иногда, если значение expr равно FALSE с самого начала, цикл не выполняется ни разу.
Как и в IF, вы можете сгруппировать несколько операторов внутри фигурных скобок или использовать альтернативный синтаксис :
WHILE(expr): выражения ... ENDWHILE;
Следующие примеры идентичны - оба выводят номера с 1 по 10:
/* example 1 */ $i = 1; while ($i <= 10) { print $i++; } /* example 2 */ $i = 1; while ($i <= 10): print $i; $i++; endwhile;
DO..WHILE
Цикл DO..WHILE очень похож на WHILE за исключением того, что значение логического выражения проверяется не до, а после окончания итерации. Основное отличие в том, что DO..WHILE гарантировано выполнится хотя бы один раз, что в случае WHILE не обязательно.
Для циклов DO..WHILE существует только один вид синтаксиса:
$i = 0; do { print $i; } while ($i>0);
Этот цикл выполнится один раз, так как после окончания итерации будет проверено значение логического выражения, а оно равно FALSE ($i не больше 0), и выполнение цикла завершится.
Опытные программисты на C может быть знакомы с иным использованием DO..WHILE, позволяющем прекратить исполнение блока операторов в середине путЈм внедрения его в цикл DO..WHILE(0) и использования оператора BREAK. Следующий код демонстрирует такую возможность :
do { if ($i < 5) { print "i is not big enough"; break; } $i *= $factor; if ($i < $minimum_limit) { break; } print "i is ok"; ...process i... } while(0);
Не беспокойтесь, если вы не совсем поняли это. Вы можете программировать весьма мощные скрипты и без этой возможности.
FOR
Циклы FOR - наиболее мощные циклы в PHP. Они работают подобно их аналогам в C. Синтаксис цикла FOR :
FOR (expr1; expr2; expr3) statement
Первое выражение (expr1) безусловно вычисляется(выполняется) в начале цикла.
В начале каждой итерации вычисляется expr2. Если оно равно TRUE, то цикл продолжается и выполняются вложенный(е) оператор(ы). Если оно равно FALSE, то цикл заканчивается.
В конце каждой итерации вычисляется(исполняется) expr3.
Каждое из этих выражений может быть пустым. Если expr2 пусто, то цикл продолжается бесконечно (PHP по умолчанию считает его равным TRUE, как и С). Это не так бесполезно, как могло бы показаться, так как зачастую вам требуется закончить выполнение цикла используя оператор BREAK в сочетании с логическим условием вместо использования логического выражения в FOR.
Рассмотрим следующие примеры. Все они выводят номера с 1 по 10 :
/* пример 1 */ for ($i = 1; $i <= 10; $i++) { print $i; } /* пример 2 */ for ($i = 1;;$i++) { if ($i > 10) { break; } print $i; } /* пример 3 */ $i = 1; for (;;) { if ($i > 10) { break; } print $i; $i++; } /* пример 4 */ for ($i = 1; $i <= 10; print $i, $i++) ;
Конечно, первый вариант кажется лучшим (или четвЈртый), но оказывавется возможность использования пустых выражений в цикле FOR зачастую оказывается полезной.
PHP также поддерживает альтернативный синтаксис FOR :
FOR (expr1; expr2; expr3): выражение; ...; endfor;
Другие языки используют оператор foreach для того, чтобы обрабатывает массивы или списки. PHP использует для этого оператор while и функции list() и each() . Для примера смотрите документацию по этим функциям.
BREAK
VREAK прерывает выполнение текущего цикла.
$i = 0; while ($i < 10) { if ($arr[$i] == "stop") { break; } $i++; }
CONTINUE
CONTINUE переходит на начало ближайшего цикла.
while (list($key,$value) = each($arr)) { if ($key % 2) { // skip even members continue; } do_something_odd ($value); }
SWITCH
Оператор SWITCH похож на группу операторов IF с одинаковым выражением. Во многих случаях вам нужно сравнить переменную (или выражение) со многими различными значениями и выполнить различные фрагменты кода в зависимости от того, чему будет равно значение выражения. Это как раз то, для чего предназначается оператор SWITCH.
Следующие 2 примера это 2 разлчиных пути для достижения одной вещи, но один использует серию операторов IF, а другой - оператор SWITCH.
/* пример 1 */ if ($i == 0) { print "i equals 0"; } if ($i == 1) { print "i equals 1"; } if ($i == 2) { print "i equals 2"; } /* пример 2 */ switch ($i) { case 0: print "i equals 0"; break; case 1: print "i equals 1"; break; case 2: print "i equals 2"; break; }
Важно понять как работает оператор SWITCH чтобы избежать ошибок. SWITCH выполняет последовательно оператор за оператором. В начале код не исполняется. Только когда встречается оператор CASE с подходящим значением, PHP начинает выполнять программу. PHP продолжает выполнять операторы до конца блока SWITCH или пока не встретит оператор BREAK. Если вы не напишете BREAK в конце цикла операторов, то PHP продолжит выполнять операторы и следующего SWITCH'а. К примеру :
/* пример 3 */ switch ($i) { case 0: print "i equals 0"; case 1: print "i equals 1"; case 2: print "i equals 2"; }
В этом случае, если $i равно 0, то PHP выполнит все операторы print! Если $i равно 1, то PHP выполнит последние два print. И только если $i равно 2, вы получите ожидаемый результат и выведено будет только 'i equals 2'. Так что важно не забывать ставить BREAK (разве что в некоторых случаях вы специально не захотите их ставить для достижения определ©нной цели).
Специальный случай - это 'default case'. Этот оператор соответствует всем значениям, которые не удовлетворяют другим case'ам. К примеру :
/* example 4 */ switch ($i) { case 0: print "i equals 0"; break; case 1: print "i equals 1"; break; case 2: print "i equals 2"; break; default: print "i is not equal to 0, 1 or 2"; }
Другой заслуживающий упоминания факт - это то, что выражения в CASE могут быть любого скалярного типа, то есть целые числа или числа с плавающей запятой, а так же строки. Массивы и объекты не будут ошибкой, но в данном случае они не имеют значимости.
REQUIRE
Оператор REQUIRE заменяет себя содержимым указанного файла, похоже на то,как в препроцессоре C работает #include.
Это означает, что вы не можете поместить require() внутрь цикла и ожидать, что он включит содержимое дугого файла несколько раз в процессе каждой итерации. Для это используйте INCLUDE.
require ('header.inc');
INCLUDE
Оператор INCLUDE вставляет и выполняет содержимое указанного файла.
Это случается каждый раз, когда встречается оператор INCLUDE, так что вы можете включить этот оператор внутрь цикла, чтобы включить несколько файлов :
$files = array ('first.inc', 'second.inc', 'third.inc'); for ($i = 0; $i < count($files); $i++) { include($files[$i]); }
include() отличается от require() тем, что оператор include выполняется каждый раз при его встрече, а require() заменяется на содержимое указанного файла безотносительно будет ли выполнено его содержимое или нет
Так как include() это специальный оператор, требуется заключать его в фигурные скобки при использовании внутри условного оператора.
/* Это неправильно и не будет работать, как хотелось бы. */ if ($condition) include($file); else include($other); /* А вот это - верно. */ if ($condition) { include($file); } else { include($other); }
Когда файл исполняется, парсер пребывает в "режиме HTML", то есть будет выводить содержимое файла, пока не встретит первый стартовый тег PHP (<?).
Продолжение следует....