PHP

Материал из Викиучебника

Перейти к: навигация, поиск

PHP (произносится пи-эйч-пи́) — скриптовый язык программирования, созданный для генерации HTML-страниц на веб-сервере и работы с базами данных. Ныне поддерживается подавляющим большинством представителей хостингов. Входит в LAMP — «стандартный» набор для создания вебсайтов.

Содержание

[править] PHP программы

Программы PHP могут выполняться двумя способами: как Web-приложение HTTP-сервером или как консольные программы. Поскольку, нашей задачей является программирование web-приложений, мы преимущественно будем рассматривать первый способ.

Дело в том, что PHP, как правило, используется сугубо для программирования приложений, связанных с Интернетом. Однако, PHP можно еще использовать в качестве интерпретатора командной строки, в основном в *nix-системах. Последнее возможно при помощи CORBA и COM интерфейсов, а также при помощи расширения PHP-GTK. При таком использовании PHP возможно решение следующих задач:

  • создание приложений интерактивной командной строки;
  • создание кросс-платформенных GUI приложений при помощи библиотек PHP-GTK, PHP-Qt или WinBinder;
  • автоматизация некоторых задач под Windows и Linux.

Рассмотрим процесс выполнения php-сценария при обращении браузера к серверу. Итак, вначале браузер запрашивает страницу с расширением .php, после чего web-сервер пропускает программу через машину PHP и выдаёт результат в виде html-кода. Причем, если взять стандартную страницу HTML, изменить расширение на .php и пропустить её через машину PHP, последняя просто перешлёт её пользователю без изменений. Чтобы включить в этот файл команды PHP, необходимо заключить команды PHP в специальные теги, которые могут быть нескольких видов, но на практике используется только один:

<?php
...
?>

и его сокращённая форма, которая работает при short_open_tag = 1 в php.ini:

<?
...
?>
примечание: закрывающий тег ?> в самом конце файла можно ( и даже желательно) не ставить

Вообще говоря, внутри какого-либо блока кода можно выйти из PHP, при условии, что дальше мы войдем в него снова и закончим код (Подробнее об этом смотрите в гл.2.). То есть, возможна следующая конструкция:

<?php
if (5 < 3) {
  print '<p>Hello, world!<p>';
?>
<p>Hello!</p>
Эта строка не интерпретируется как код PHP
и выводится только если  блок кода выполняется
<?
  print '<p>Hello, world!<p>';
}

Функция print в PHP применяется для вывода фактически всего, что встречается на web-страницах (текст, разметку HTML, числа). Смысл ее действия, мы думаем, понятен из приведенного примера. Если включена поддержка сокращённой инструкции обработки, то вместо

<? print 'Test' ?>

можно писать

<?='Test'?>

[править] Комментарии

PHP предоставляет несколько методов для вставки комментариев. Проще всего пользоваться двойным слэшем (//), после чего PHP машина игнорирует все, что расположено до конца строки. Также можно пользоваться многострочными комментариями в стиле С (/*…*/). Для однострочных комментариев можно еще пользоваться символом решетки (#) (комментарий скриптовых языков UNIX).

<?php
print '<p>Hello</p>'; // комментарий
print '<p>Hello</p>'; # комментарий
/** 
 * и это тоже комментарии
 */
?>

Следует помнить о том, что стили комментариев PHP действуют только внутри ограничителей PHP. Если PHP встретит эти символы комментариев вне ограничителей, то они, как и любой текст, будут помещены на html-страницу. Например:

<?php
print '<p>Hello</p>'; // нормальный комментарий
?>
// а вот этот комментарий отобразится браузером.
<!-- Комментарий  HTML. Будет виден в исходном коде HTML, но не в браузере  -->

Заметим, что комментарии можно вставлять не только после конца оператора, а, например, и вот так:

<?php
$a = 'Hello, world';
print strstr($a, 'H');
// эту функцию мы рассмотрим позднее

[править] Переменные

В РНР переменные начинаются со знака доллара ($). За этим знаком может следовать любое количество буквенно-цифровых символов и символов подчеркивания, но первый символ не может быть цифрой или подчеркиванием. Следует также помнить, что имена переменных в РНР чувствительны к регистру, в отличие от ключевых слов.

При объявлении переменных в РНР не требуется явно указывать тип переменной, при этом одна и та же переменная может иметь на протяжении программы разные типы.

Переменная инициализируется в момент присваивания ей значения и существует до тех пор, пока выполняется программа (т.е., в случае web-страницы это означает, что до тех пор, пока не завершен запрос.), или она не будет удалена функцией unset().

[править] Функции вывода

В PHP существует несколько способов вывести что-либо в веб страницу:

  • Операторы echo и print
    Работают одним и тем же образом. Выводят значение аргумента.
  • print_r()
    Позволяет корректно выводить массивы
  • var_dump()
    Выводит переменную вместе с типом. Очень удобный инструмент для отладки

[править] Вывод различных функций

Аргумент echo print_r() var_dump()
1 1 1 int(1)
false     bool(false)
array( 1, 2, 3 ) Array Array

(

   [0] => 1
   [1] => 2
   [2] => 3

)

array(3) {
 [0]=>
 int(1)
 [1]=>
 int(2)
 [2]=>
 int(3)

}

"Test" Test Test string(4) "Test"

[править] Типы данных в РНР

Как уже было сказано, PHP предоставляет определенную гибкость в отношении типов переменных, т.е. с одной и той же переменной на протяжении программы можно работать и как со строкой, и как с числом. Однако, несмотря на это в РНР существуют набор основных типов данных, которые могут явно указываться при работе с переменными:

  • integer;
  • string;
  • boolean;
  • double;
  • array;
  • object;

Есть функция gettype(), возвращающая тип, который РНР назначил переменной:

<?php
$var1= '5';
$var2 = 5;
echo gettype($var1) // string
     . '<br>'
     . gettype($var2); // integer

В первом случае РНР вернет string, во втором integer.

Существует также функция settype(), которая явно устанавливает тип:

<?php
$var = '5';
echo gettype($var);
settype($var, 'integer');
echo '<br>'
     . gettype($var);

Выполнение этого фрагмента кода приведет к такому же результату, как и предыдущего.

Кроме функции settype() преобразование типов в РНР можно осуществлять при помощи операторов преобразования типов. Преобразование типов осуществляется путем указания перед переменной ее нового типа, взятого в скобки:

$var = (int)$var;

Соответственно, выполнение следующего кода приведет к тому, что РНР вернет integer:

<?php
$var = '5'; // тип string
$var = (int)$var; // преобразуем в int
echo gettype($var);

[править] Внешние переменные

После того, как запрос клиента проанализирован веб-сервером и передан РНР-интерпретатору, последний устанавливает ряд переменных, которые содержат данные, относящиеся к запросу и доступны все время его выполнения.

Сначала PHP инициализирует массивы $_ENV (переменные окружения) и $_SERVER[1]. Массив $_SERVER содержит следующие ключи:

  • $_SERVER['HTTP_USER_AGENT'] — браузер клиента
  • $_SERVER['HTTP_ACCEPT'] — принимаемые MIME-типы. Может служить для определения возможностей браузера
  • $_SERVER['PHP_SELF'] — путь скрипту относительно корня сервера. Пример: /w/index.php

Затем РНР заполняет $_GET, которые создаются при анализе строки запроса. Строка запроса хранится в переменной $_SERVER['QUERY_STRING'] и представляет собой информацию, следующую за символом «?» в запрошенном URL. РНР разбивает строку запроса по символам &[2] на отдельные элементы, а затем ищет в каждом из этих элементов знак «=». Если знак «=» найден, то создается переменная с именем из символов, стоящих слева от знака равенства. Рассмотрим следующую форму:

<form action="http://localhost/PHP/test.php" method="get">
  HDD: <input type="text" name="HDD"><br>
  CDROM: <input type="text" name="CDROM"><br>
  <input type="submit">
</form>

Если Вы в этой форме в строке HDD наберете, к примеру, «Maxtor», а в строке CDROM «Nec», то она сгенерирует следующую форму запроса: http://localhost/PHP/test.php?HDD=Maxtor&CDROM=Nec

В нашем случае РНР создаст следующие переменные: $_GET['HDD'] = 'Maxtor' и $_GET['CDROM'] = 'Nec'.

Вы можете работать с этими переменными из Вашего скрипта (у нас — test.php) как с обычными переменными. В нашем случае они просто выводятся на экран:

<?php
echo "<p>HDD is {$_GET['HDD']}</p>";
echo "<p>CDROM is {$_GET['CDROM']}</p>";

Если запрос страницы выполняется при помощи метода POST, то появляется группа POST-переменных, которые интерпретируются также и помещаются в массив $_POST.

[править] Константы

Константы объявляются в РНР при помощи функции define():

define('CONSTANT', value)

Первый параметр этой функции – имя константы, второй – её значение. При использовании константы на неё ссылаются по имени:

<?php
  define('CONSTANT1', 15);
  define('CONSTANT2', "\x20"); // код пробела
  define('CONSTANT3', 'Hello');
  echo CONSTANT1;
  echo CONSTANT2;
  echo CONSTANT3;

По традиции имена констант пишут буквами верхнего регистра. И хотя это только традиция, мы Вам рекомендуем ей следовать, поскольку плохие программисты получаются в том числе и из тех, кто не следовал хорошим традициям. Существует функция defined(), которая проверяет, определена ли константа:

<?php
define('CONSTANT', 'Hello');
if (defined('CONSTANT')) {
  echo '<p>CONSTANT is defined</p>';
}

[править] Операторы

[править] Математические операторы

В PHP, как и в любом другом языке программирования, есть базовый набор математических операторов:

  • Унарный минус (-) — изменяет знак числа
  • Сложение, вычитание, умножение (+, -, *) — действуют также как и в обычной математике
  • Деление (/) всегда возвращает вещественное число, вне зависимости от результата.
  • Деление по модулю (%) — остаток от деления

[править] Инкремент и декремент

  • $a++ возвращает старое значение $a и увеличивает $a на 1
  • ++$a увеличивает $a на 1 и возвращает новое значение $a
  • $a-- возвращает старое значение $a и уменьшает $a на 1
  • --$a уменьшает $a на 1 и возвращает новое значение $a

[править] Операторы сравнения

Существуют следующие операторы сравнения:

$a == $b true если $a равно $b
$a === $b true если $a равно $b и они имеют один и тот же тип
$a != $b или $a <> $b true если $a не равно $b
$a > $b true если $a больше $b
$a < $b true если $a меньше $b
$a >= $b true если $a больше или равно $b
$a <= $b true если $a меньше или равно $b

[править] Операторы присвоения

Для присвоения переменной нового значения используется оператор "=":

$a = $b + $c - 127;

Также существуют сокращённые операторы присвоения(+=, -=, .=, /=, *=, %=):

$a = $a + 1;
# равносильно
$a += 1;

[править] if...else

Оператор if позволяет выполнять определённый код только при выполнении определённого условия:

<?php
$a = 1;
$b = null;
$c = 2 * 3;
$d = true;
if ($a) {
 echo "if(\$a);<br>";
}
if($b) {
 echo "if(\$b);<br>";
}
if($c) {
 echo "if(\$c);<br>";
}
if(!$d) {
 echo "if(!\$d);<br>";
}
if($a < $c) {
 echo "\$a < \$c;<br>";

Этот код выводит следующие строки:

if($a);
if($c);
$a < $c;

Для того, чтобы выполнять код только если условие не выполнилось, можно использовать блок else:

<?php
if (isset($_GET['test'])) {
 echo 'Query contains "test" parameter';
} else {
 echo 'Query doesn\'t contain "test" parameter';
}

Можно использовать инструкцию elseif:

<?php
if ($_GET['test'] == "foo") {
 echo 'test = "foo"';
} elseif( isset( $_GET['test'] ) {
 echo 'Query contains "test" parameter, but it isn\'t "foo"';
} else {
 echo 'Query doesn\'t contain "test" parameter';
}

[править] Переключатель switch

<?php
$a = "A";
switch ($a) {
    case 'A':
        echo 'Переменная имеет значение "А"';
        break;
    case 'B':
        echo 'Переменная имеет значение "B"';
        break;
    default:
        echo 'Ответ не найден';
}

Данный пример выведет «Переменная имеет значение "A"»

[править] Операторы цикла

Операторы цикла задают многократное исполнение операторов в теле цикла. В PHP определены 4 разных оператора цикла:

  • цикл с предусловием: while (condition) { statements; }
  • цикл с постусловием: do { statements; } while(condition);
  • итерационный цикл: for (expression1; expression2; expression3) { statements; }
  • итерационный цикл foreach: foreach (array as [$key =>] $value) { statements; }

Если 3 первых оператора цикла берут свое начало от С-подобных языков, то последний оператор позаимствован у языка Perl.

[править] While

Оператор while называется оператором цикла с предусловием. При входе в цикл вычисляется выражение условие, и, если его значение отлично от нуля, выполняется тело цикла. Затем вычисления выражения условия и операторов тела цикла выполняется до тех пор, пока значение выражения условия не станет равным нулю. Оператором while удобно пользоваться для просмотра всевозможных последовательностей, если в конце них находится заранее известный символ. (Это очень удобно в C++, к примеру для определения длины строки, поскольку в С++, по определению, строка есть последовательность символов типа char, заканчивающаяся нулевым символом).

Пример простейшего цикла while:

<?php
$var = 5;
$i = 0;
while (++$i <= $var) {
  echo $i . '<br />';
}

Этот код выдает в окне браузера цифры от одного до пяти.

Для выхода из цикла применяется оператор break. При обнаружении этого оператора текущая итерация цикла прекращается, и последующие итерации не происходят. При выполнении следующего примера, несмотря на то, что переменная $var = 7, в окне браузера появятся цифры от 1 до 5.

<?php
$var = 7;
$i = 0;
while (++$i <= $var) {
  echo $i . '<br />';
  if ($i == 5) break;
}

Иногда бывает нужно прервать только текущую итерацию, и перейти сразу к следующей. Для этого применяется оператор continue:

<?php
$var = 7;
$i = 0;
while (++$i <= $var) {
  if ($i == 5) {
    continue;
  }
  echo $i . '<br />';
}

В этом примере выводятся цифры от 1 до 7, кроме цифры 5.

Заметим, что если Вы условный оператор поставите после операторов echo, код будет ошибочным, и выведутся все цифры от 1 до 7, поскольку проверка условия выхода из цикла на данной итерации, будет происходить уже после выполнения этой итерации.

Бесконечный цикл реализуется при помощи оператора while следующим образом:

while(1) {
  ...
}

Это то же самое, что и запись while(true) {...}. Примечание: В PHP стандартное время исполнения скрипта — 30 секунд (эту настройку можно изменить в php.ini). То есть по прошествии 30 секунд с начала выполнения скрипта, его действие будет прервано. Таким образом, время выполнения бесконечного цикла — полминуты.

[править] Do…while

Этот оператор называется оператором цикла с постусловием. При входе в цикл в любом случае выполняется тело цикла (то есть цикл всегда будет выполнен хотя бы один раз), затем вычисляется условие, и если оно не равно 0, вновь выполняется тело цикла. В нижеследующем примере ноль всегда будет добавлен в список, независимо от условия (++$i <= $var):

<?php
$var = 5;
$i = 0;
do {
  echo $i . '<br />';
} while (++$i <= $var)

Результат:

0<br />
1<br />
2<br />
3<br />
4<br />
5<br />

Цикл с постусловием бывает полезен при обработке некоторых последовательностей, когда обработку нужно заканчивать не до, а после появления концевого признака.

Бесконечный цикл реализуется так:

do ; while(1);

[править] For

Как уже говорилось, итерационный цикл имеет следующий формат:

for (expression1; expression2; expression3) {
  statements;
}

Здесь expression1 (инициализация цикла) — последовательность определений и выражений, разделяемая запятыми. Все выражения, входящие в инициализацию, вычисляются только один раз при входе в цикл. Как правило, здесь устанавливаются начальные значения счетчиков и параметров цикла. Смысл выражения-условия (expression2) такой же как и у циклов с пред- и постусловиями. При отсутствии выражения-условия предполагается, что его значение всегда истинно. Выражения expression3 вычисляются в конце каждой итерации после выполнения тела цикла.

В следующем скрипте, мы по традиции выведем числа от 0 до 5:

<?php
$var = 5;
$i = 0;
for ($i = 0; $i <= $var; $i++) {
  echo $i . '<br>';
}

Результат аналогичен, показанному на предыдущем рисунке.

Бесконечный цикл можно организовать следующим образом:

for(;;);

[править] Foreach

Оператор цикла foreach предназначен для работы с элементами массива. Следующий код превратит все элементы массива в единицы.

<?php
  $arr = array (1, 2, 3, 4);
  $i = 0;
  foreach ($arr as $a)
    $a -= $i++;

Также предусмотрена возможность работы с ассоциативными массивами. При обработке следующего кода в переменной $name будет храниться ассоциативный индекс элемента, а в переменной $value — его значение. Проще говоря, ($arr[$name] == $value).

<?php
  // ...
  foreach ($arr as $name => $value) {
      /* тело цикла */
  }

[править] Тернарный оператор ?:

Тернарный оператор "?:" это вид условного оператора, он проверяет Выражение 1 и если оно верно, то присваивает значение Выражения 2, иначе - Выражения 3.

<?php
  $a = true;
  $b = false;
  $c = 11;
  $d = 10;
  $f = $a ? $c : $d; // Переменной $f присвоится значение переменной $c, т.к. значение выражения $a истинно
  $g = $b ? $c : $d; // Здесь наоборот - $g будет присвоено значение $d
  $h = (!empty($n)) ? $n : $c+$d; // Сперва проверится существование переменной $n,
                                  // а т.к. она не существует, переменной $h присвоится сумма $c и $d, т.е. 21
?>

[править] Строковые функции PHP

Несмотря на то, что эта глава написана скорее в духе справочника, материал, изложенный в ней, достаточно серьезен, хотя и не самый сложный для понимания. Умение грамотно работать со строками очень важно для программиста. Строковых функций в PHP немало, причем многие из них, так или иначе, просто дублируют друг друга. Однако, приемы работы с основными блоками функций (функции поиска и замены в тексте, функции удаления пробельных символом (trim-функции), функции форматного вывода) надо представлять очень четко.

Вообще говоря, по определению, строка — это последовательность символов типа char, которая заканчивается нулевым символом. Поэтому, можно, конечно, радоваться тому, что при работе со строками, нам не приходится жонглировать указателями в стиле C/C++, однако не стоит забывать о том, что цена этому удобству — быстродействие. Поэтому некоторые приводимые здесь функции мы будем обсуждать в том числе и с точки зрения их быстродействия.

[править] Функция htmlspecialchars

string htmlspecialchars(string $str)

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

Пример

корректное формирование и вывод гиперссылки, содержащей определённые параметры:

$link_search_subject = "Экранирование";
$link_label = "Поиск по слову <<$link_search_subject>>";
 
echo 
    '<a href="'.htmlspecialchars("http://ru.wikibooks.org/wiki/Служебная:Search?search=".urlencode($link_search_subject)."&go=".urlencode("Перейти")).'">'.
        htmlspecialchars($link_label).
    '</a>';

заметьте, что следующий (ниже представленный) код, содержит грубое нарушение, так как формирует гиперссылку с аттрибутом содержащим незаконченную (не закрытую) ссылку на сущность (&...;) :

$link_search_subject = "Экранирование";
 
echo 
    '<a href="http://ru.wikibooks.org/wiki/Служебная:Search?search='.urlencode($link_search_subject).'&go='.urlencode("Перейти").'">'. // НАРУШЕНИЕ!!
        "Поиск по слову Экранирование".
    '</a>';

это довольно часто встречаемая ошибка.

[править] Функции поиска в тексте

[править] substr()

Функция substr() возвращает часть строки. Например:

echo substr('Simple text', 3, 7);

Где 3 — точка отсчета, а 7 — длина изымаемой строки. Если же требуется вести отсчет от конца строки, используйте отрицательное значение.

Пример

Эта функция разобьет число по трём разрядам:

function my_int($value)
{
  $len = strlen($value);
  if ($len <= 3) {
      return $value;
  } else {
      return my_int(substr($value, 0, $len-3)) . ' ' . substr($value, $len-3, 3);
  }
}
 
echo my_int(12345678); //=> 12 345 678

[править] strpos()

int strpos (string haystack, string needle [, int offset])

Возвращает позицию первого вхождения подстроки needle в строку haystack. Необязательный аргумент offset позволяет указать, с какого по счету символа строки haystack начинать поиск.

Если подстрока needle не найдена, strpos() возвращает FALSE.

Пример:

Эта функция определяет модель браузера:

function getCurrentBrowser() {
    $browser = strtoupper($_SERVER['HTTP_USER_AGENT']);
    if (strpos($browser, 'MSIE') !== false) { $browser = 'Internet Explorer';} 
    else if (strpos($browser, 'FIREFOX') !== false){ $browser = 'Firefox'; } 
    else if (strpos($browser, 'KONQUEROR') !== false){ $browser = 'Konqueror'; } 
    else if (strpos($browser, 'LYNX') !== false){ $browser = 'Lynx'; } 
    else { $browser = $_SERVER['HTTP_USER_AGENT']; }
    return $browser;
}

[править] strrpos()

Возвращает позицию последнего вхождения символа

int strrpos (string haystack, string needle [, int offset])

Возвращает позицию последнего вхождения needle в строку haystack. В PHP 4 используется только первый символ строки needle.

Начиная с PHP 5 необязательный аргумент offset позволяет указать, с какого по счету символа строки haystack начинать поиск. Отрицательное значение предписывает прекратить поиск при достижении определенной позиции до конца строки.

Если подстрока needle не найдена, возвращает FALSE.


Пример:

Эта функция достаёт из URL имя файла (только пример, в жизни можно использовать функцию basename()):

function getfname($url)
{
    $pos = strrpos($url, '/', 8); // начиная с 8 символа, т.к. в "http://" искать не нужно
    $filename = '';
    if ($pos === false) {
        // Ошибка, url задан неверно.
        return false;
    } else {
        $filename = substr($url, $pos + 1);
    }
    return $filename;
}

[править] strstr(), stristr()

string strstr (string $haystack, string $needle)

Возвращает подстроку строки haystack начиная с первого вхождения подстроки needle до конца строки. Функция stristr() выполняет ту же функцию, но не чувствительна к регистру.

Пример:

<?php
$text = 'www.wikibooks.org';
$strstr = strstr($text, '.');
print $strstr;
?>

Данный пример выведет «.wikibooks.org».

[править] strchr()

Эта функция является псевдонимом функции strstr().

[править] strrchr()

string strrchr (string $haystack, char $needle)

Возвращает подстроку строки haystack начиная с последнего вхождения needle до конца строки.

Если подстрока needle не найдена, возвращает FALSE.

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

Если needle не является строкой, он приводится к целому и трактуется как код символа.

Пример:

<?php
$text = 'www.wikibooks.org';
$strrchr = strrchr($text, '.');
print $strrchr;
?>

Данный пример выведет «.org».

[править] substr_count()

int substr_count (string $haystack, string $needle)

Возвращает число вхождений подстроки needle в строку haystack.

Можно использовать или текст в кавычках (или апострофах) или переменные.

Пример:

<?php
print substr_count('www.wikibooks.org', 'o');
?>

Данный пример выведет «3».

[править] strspn()

[править] strcspn()

[править] Регулярные выражения

[править] Примечания

  1. На самом деле, порядок инициализации суперглобальных массивов зависит от настроек в файле php.ini
  2. Символ разделения так может меняться в файле php.ini, часто используется символ «;»

↑ На самом деле, порядок инициализации суперглобальных массивов зависит от настроек в файле php.ini ↑ Символ разделения также может меняться в файле php.ini, часто используется символ «;»

[править] Ссылки

Источник — «http://ru.wikibooks.org/wiki/PHP»