Технологія SSI (Server Side Includes) – потужний та гнучкий засіб для динамічного формування веб-сторінок на стороні сервера. Суть технології полягає в препроцессингу сторінок, що запитуються на серверній стороні на предмет пошуку в них спеціальних команд - директив SSI.
Директиви SSI дозволяють використовувати в HTML документах такі можливості як виконання інших програм, отримання інформації про файли та змінні оточення, об'єднання кількох файлів в один.
Якщо сервер не налаштований на підтримку SSI, команди SSI не обробляються і відправляються користувачеві як є і у веб-сторінці виглядають як коментар.
Чтобы передать переменную, включая переменные среды (например, LAST_MODIFIED), надо указать что это есть переменная, а не буквальная строка, используя знак доллара $ перед именем переменной.
Наконец, если вы хотите поместить переменную в более длинную строку, и есть вероятность, что имя переменной столкнется с некоторыми другими символами и, таким образом, будет смущено этими символами, вы можете поместить имя переменная в фигурных скобках, чтобы устранить эту путаницу.
This comment tag allows a web page designer to insert comments into the .html or .shtml file without having those comments displayed when the browser serves up the page.
Any
<!--#comment -->
which includes the # pound sign is interpreted by the SSI enabled server as a command rather than as a comment. Since it is in the form of a comment, it does not get displayed by the browser. Since it has the pound sign it is interpreted as a command and the results of that command are then displayed by the browser. Commands can vary widely from server to server but the 'echo' command is one of the most common. "Echo" returns to the .shtml document the results of the command.
| TIME_YEAR | Текущий год (например 2010) | | TIME_MON | Текущий месяц ( 01, ..., 12) | | TIME_DAY | Текущий день месяца ( 01, ...) | | TIME_HOUR | Часовая часть текущего времени ( 00, ..., 23) | | TIME_MIN | Минувшая часть текущего времени | | TIME_SEC | Вторая часть текущего времени | | TIME_WDAY | День недели (начиная с 0 воскресенья) | | TIME | Дата и время в формате 20101231235959 | | SERVER_SOFTWARE | Строка версии сервера | | API_VERSION | Дата версии API (макс. Номер модуля) |
Подробнее
Настройка сервера
Модулем SSI по умолчанию обрабатываются файлы с расширением .shtml и .shtm , но можно настроить сервер и на обработку файлов .html и .htm. Для этого необходимо указать в конфигурационном файле Apache (httpd.conf) или в пользовательском файле управления каталогами .htaccess следующие строки:
Примечание: Файл httpd.conf отвечает за настройку всего веб-сервера, не доступен непривилегированному пользователю. Скрытый (dot-файл) .htaccess размещается в пользовательских каталогах и отвечает за их настройки.
Формат директив SSI
Общий синтаксис директивы SSI таков:
<!--#команда параметр="значение"-->
Некоторые команды имеют еще и подкоманды:
&&подкоманда&&
Директивы SSI
В табл. 1 перечислены основные директивы SSI.
Табл.1 Директивы SSI
<td>Вставка в документ переменных среды (браузер, дата, имя документа, ...).</td>
</tr>
<tr>
<td>include</td>
<td>Включение файла в HTML документ.</td>
</tr>
<tr>
<td>fsize</td>
<td>Включение размера файла в HTML документ.</td>
</tr>
<tr>
<td>flastmod </td>
<td>Включение даты последней модификации файла в HTML документ.</td>
</tr>
<tr>
<td>exec</td>
<td>Выполнение внешнего исполняемого файла (CGI программы). Выходной поток данных (стандартный вывод) этой программы включается в документ.</td>
</tr>
<tr>
<td>config</td>
<td>Установка параметров для SSI+ команд.</td>
</tr>
<tr>
<td>odbc</td>
<td>Обращение к внешней ODBC СУБД.</td>
</tr>
<tr>
<td>email</td>
<td>Отправка электронной почты или представление формы.</td>
</tr>
<tr>
<td>if</td>
<td>Условный оператор, управляющий выполнением других команд SSI и вывода документа.</td>
</tr>
<tr>
<td>goto</td>
<td>Оператор перехода на определенную SSI метку (label).</td>
</tr>
<tr>
<td>label</td>
<td>Метка в документе.</td>
</tr>
<tr>
<td>break</td>
<td>Остановка вывода документа.</td>
</tr>
Рассмотрим некоторые из перечисленных директив более подробно.
echo
<!--#echo var="переменная_среды"-->
Предназначена для вставки в документ значений специальных переменных SSI, а также других переменных среды.
Пример:
<!--#echo var="HTTP_USER_AGENT"-->
Некоторые переменные окружения:
<td>локальное имя файла</td>
</tr>
<tr>
<td>DOCUMENT_URI</td>
<td>URL файла</td>
</tr>
<tr>
<td>DATE_LOCAL</td>
<td>Текущая дата и время (локаль сервера)</td>
</tr>
<tr>
<td>DATE_GMT</td>
<td>Текущая дата и время по Гринвичу</td>
</tr>
<tr>
<td>LAST_MODIFIED</td>
<td>Дата и время последнего изменения текущего файла</td>
</tr>
<tr>
<td>REMOTE_ADDR</td>
<td>IP адрес удаленного клиента</td>
</tr>
<tr>
<td>QUERY_STRING</td>
<td>Строка, полученная от клиента</td>
</tr>
<tr>
<td>SERVER_SOFTWARE</td>
<td>Имя HTTP server software</td>
</tr>
<tr>
<td>SERVER_NAME</td>
<td>Имя компьютера, на котором работает WWW сервер</td>
</tr>
<tr>
<td>REMOTE_HOST</td>
<td>Имя компьютера удаленного клиента</td>
</tr>
<tr>
<td>HTTP_USER_AGENT</td>
<td>Имя браузера клиента (browser software).</td>
</tr>
<tr>
<td>HTTP_REFERER</td>
<td>URL адрес HTML документа из которого сделан запрос клиентом</td>
</tr>
errmsg - формат сообщения об ошибке, которое выдается когда обработчик SSI+ обнаруживает ошибки. Для SSI+ также можно использовать onerr.
Пример: <!--#config errmsg="Ошибка обработки SSI запроса"-->
sizefmt - формат информации об объеме файла. Допустимые значения sizefmt - bytes или addrev. Они задают округление значения объема файла до ближайшего килобайта.
<th>Значение</th>
<th>Пример</th>
</tr>
<tr>
<td>%a</td>
<td>День недели в сокращенном виде</td>
<td>Sun</td>
</tr>
<tr>
<td>%A</td>
<td>День недели</td>
<td>Sunday</td>
</tr>
<tr>
<td>%b</td>
<td>Месяц в сокращенном виде (также %h)</td>
<td>Jan</td>
</tr>
<tr>
<td>%B</td>
<td>Месяц </td>
<td>January</td>
</tr>
<tr>
<td>%d</td>
<td>Дата </td>
<td>01</td>
</tr>
<tr>
<td>%D</td>
<td>Дата в формате %m/%d/%y</td>
<td>06/23/99</td>
</tr>
<tr>
<td>%e</td>
<td>Дата</td>
<td>1</td>
</tr>
<tr>
<td>%H</td>
<td>Время в часах в 24-часовой системе</td>
<td>13</td>
</tr>
<tr>
<td>%I</td>
<td>Время в часах в 12-часовой системе</td>
<td>01</td>
</tr>
<tr>
<td>%m</td>
<td>Номер месяца</td>
<td>11</td>
</tr>
<tr>
<td>%M</td>
<td>Количество минут</td>
<td>08</td>
</tr>
<tr>
<td>%p</td>
<td>AM|PM</td>
<td>AM</td>
</tr>
<tr>
<td>%r</td>
<td>Время в формате %I:%M:%p</td>
<td>09:21:13 PM</td>
</tr>
<tr>
<td>%S</td>
<td>Количество секунд</td>
<td>09</td>
</tr>
<tr>
<td>%T</td>
<td>Время в 24-часовой системе в формате %H:%M:%S</td>
<td>12:22:40</td>
</tr>
<tr>
<td>%Y</td>
<td>Год</td>
<td>1996</td>
</tr>
Применение SSI
Пожалуй, наиболее значимым достоинством SSI является возможность выполнять шаблонную верстку веб-страниц, собирая их из нескольких файлов. Дело в том, что обычно страницы сайта включают некоторую часть одинаковой информации. Вынося такого рода фрагменты html-кода в отдельные файлы, можно затем повторно использовать их, собирая страницы с помощью SSI.
Типичный пример - это вынесение в отдельный файл логотипа страницы и меню навигации ("шапка"), в другой файл - нижнего колонтитула ("подвал" страницы), тогда третья часть такой страницы может содержать различную информацию. Такой подход позволяет ускорить разработку новых сайтов и упростить модернизацию имеющихся.
Более подробный список переменных strftime
What follows is a summary of the various strftime time output format manipulations available:
%A is replaced by national representation of the full weekday name.
<!--#config timefmt="%A" -->
<B>%a</B> is replaced by national representation of the abbreviated weekday name, where the abbreviation is the first three characters. <!--#config timefmt="%a" --> <!--#config timefmt="%a" --><!--#echo var="DATE_LOCAL" --> <B>%B</B> is replaced by national representation of the full month name. <!--#config timefmt="%B" --> <!--#config timefmt="%B" --><!--#echo var="DATE_LOCAL" --> <B>%b</B> is replaced by national representation of the abbreviated month <!--#config timefmt="%b" --> <!--#config timefmt="%b" --><!--#echo var="DATE_LOCAL" --> name, where the abbreviation is the first three characters. <B>%C</B> is replaced by (year / 100) as decimal number; single digits are preceded by a zero. <!--#config timefmt="%C" --> <!--#config timefmt="%C" --><!--#echo var="DATE_LOCAL" --> <B>%c</B> is replaced by national representation of time and date (the format is similar with produced by asctime(3)). <!--#config timefmt="%c" --> <!--#config timefmt="%c" --><!--#echo var="DATE_LOCAL" --> <B>%D</B> is equivalent to ``%m/%d/%y''. <!--#config timefmt="%D" --> <!--#config timefmt="%D" --><!--#echo var="DATE_LOCAL" --> <B>%d</B> is replaced by the day of the month as a decimal number (01-31). <!--#config timefmt="%d" --> <!--#config timefmt="%d" --><!--#echo var="DATE_LOCAL" --> <B>%e</B> is replaced by the day of month as a decimal number (1-31); single digits are preceded by a blank. <!--#config timefmt="%e" --> <!--#config timefmt="%e" --><!--#echo var="DATE_LOCAL" --> <B>%H</B> is replaced by the hour (24-hour clock) as a decimal number (00-23). <!--#config timefmt="%H" --> <!--#config timefmt="%H" --><!--#echo var="DATE_LOCAL" --> <B>%h</B> the same as %b. <!--#config timefmt="%h" --> <!--#config timefmt="%h" --><!--#echo var="DATE_LOCAL" --> <B>%I</B> is replaced by the hour (12-hour clock) as a decimal number (01-12). <!--#config timefmt="%I" --> <!--#config timefmt="%I" --><!--#echo var="DATE_LOCAL" --> <B>%j</B> is replaced by the day of the year as a decimal number (001-366). <!--#config timefmt="%j" --> <!--#config timefmt="%j" --><!--#echo var="DATE_LOCAL" --> <B>%k</B> is replaced by the hour (24-hour clock) as a decimal number (0-23); <!--#config timefmt="%k" --> <!--#config timefmt="%k" --><!--#echo var="DATE_LOCAL" --> <B>%l</B> is replaced by the hour (12-hour clock) as a decimal number (1-12); single digits are preceded by a blank. <!--#config timefmt="%l" --> <!--#config timefmt="%l" --><!--#echo var="DATE_LOCAL" --> <B>%M</B> is replaced by the minute as a decimal number (00-59). <!--#config timefmt="%M" --> <!--#config timefmt="%M" --><!--#echo var="DATE_LOCAL" --> <B>%m</B> is replaced by the month as a decimal number (01-12). <!--#config timefmt="%m" --> <!--#config timefmt="%m" --><!--#echo var="DATE_LOCAL" --> <B>%n</B> is replaced by a newline. <B>%p</B> is replaced by national representation of either "ante meridiem" or "post meridiem" as appropriate. <!--#config timefmt="%p" --> <!--#config timefmt="%p" --><!--#echo var="DATE_LOCAL" --> <B>%R</B> is equivalent to ``%H:%M''. <!--#config timefmt="%R" --> <!--#config timefmt="%R" --><!--#echo var="DATE_LOCAL" --> <B>%r</B> is equivalent to ``%I:%M:%S %p''. <!--#config timefmt="%A" --> <!--#config timefmt="%A" --><!--#echo var="DATE_LOCAL" --> <B>%S</B> is replaced by the second as a decimal number (00-60). <!--#config timefmt="%S" --> <!--#config timefmt="%S" --><!--#echo var="DATE_LOCAL" --> <B>%s </B> is replaced by the number of seconds since the Epoch, UTC (see mktime(3)). <!--#config timefmt="%s" --> <!--#config timefmt="%s" --><!--#echo var="DATE_LOCAL" --> <B>%T</B> is equivalent to ``%H:%M:%S''. <!--#config timefmt="%T" --> <!--#config timefmt="%T" --><!--#echo var="DATE_LOCAL" --> <B>%t</B> is replaced by a tab. <B>%U</B> is replaced by the week number of the year (Sunday as the first day of the week) as a decimal number (00-53). <!--#config timefmt="%A" --> <!--#config timefmt="%A" --><!--#echo var="DATE_LOCAL" --> <B>%u</B> is replaced by the weekday (Monday as the first day of the week) as a decimal number (1-7). <!--#config timefmt="%u" --> <!--#config timefmt="%u" --><!--#echo var="DATE_LOCAL" --> <B>%V</B> is replaced by the week number of the year (the first Monday as the first day of week 1) as a decimal number (01-53). <!--#config timefmt="%V" --> <!--#config timefmt="%V" --><!--#echo var="DATE_LOCAL" --> <B>%v</B> is equivalent to ``%e-%b-%Y''. <!--#config timefmt="%v" --> <!--#config timefmt="%v" --><!--#echo var="DATE_LOCAL" --> <B>%W</B> is replaced by the week number of the year (Monday as the first day of the week) as a decimal number (00-53). <!--#config timefmt="%W" --> <!--#config timefmt="%W" --><!--#echo var="DATE_LOCAL" --> <B>%w</B> is replaced by the weekday (Sunday as the first day of the week) as a decimal number (0-6). <!--#config timefmt="%w" --> <!--#config timefmt="%w" --><!--#echo var="DATE_LOCAL" --> <B>%X</B> is replaced by national representation of the time. <!--#config timefmt="%X" --> <!--#config timefmt="%X" --><!--#echo var="DATE_LOCAL" --> <B>%x</B> is replaced by national representation of the date. <!--#config timefmt="%x" --> <!--#config timefmt="%x" --><!--#echo var="DATE_LOCAL" --> <B>%Y</B> is replaced by the year with century as a decimal number. <!--#config timefmt="%Y" --> <!--#config timefmt="%Y" --><!--#echo var="DATE_LOCAL" --> <B>%y</B> is replaced by the year without century as a decimal number (00-99). <!--#config timefmt="%y" --> <!--#config timefmt="%y" --><!--#echo var="DATE_LOCAL" --> <B>%Z</B> is replaced by the time zone name. <!--#config timefmt="%Z" --> <!--#config timefmt="%Z" --><!--#echo var="DATE_LOCAL" --> <B>%+</B> is replaced by national representation of the date and time (the format is similar with produced by date(1)). <!--#config timefmt="%+" --> <!--#config timefmt="%+" --><!--#echo var="DATE_LOCAL" --> <B>%%</B> is replaced by `%'.