Модуль ngx_http_ssi_module — это фильтр,
обрабатывающий команды SSI (Server Side Includes) в проходящих
через него ответах.
На данный момент список поддерживаемых команд SSI неполон.
Пример конфигурации
location / {
ssi on;
...
}
Директивы
синтаксис:
|
ssi on | off ;
|
умолчание:
|
ssi off;
|
контекст:
|
http , server , location , if в location
|
Разрешает или запрещает обработку команд SSI в ответах.
синтаксис:
|
ssi_min_file_chunk размер ;
|
умолчание:
|
ssi_min_file_chunk 1k;
|
контекст:
|
http , server , location
|
Задаёт минимальный размер частей ответа, хранящихся
на диске, начиная с которого имеет смысл посылать их с помощью
sendfile.
синтаксис:
|
ssi_silent_errors on | off ;
|
умолчание:
|
ssi_silent_errors off;
|
контекст:
|
http , server , location
|
Разрешает не выводить строку
“[an error occurred while processing the directive] ”,
если во время обработки SSI произошла ошибка.
синтаксис:
|
ssi_types mime-тип ...;
|
умолчание:
|
ssi_types text/html;
|
контекст:
|
http , server , location
|
Разрешает обработку команд SSI в ответах с указанными MIME-типами
в дополнение к “text/html ”.
Специальное значение “* ” соответствует любому MIME-типу
(0.8.29).
синтаксис:
|
ssi_value_length длина ;
|
умолчание:
|
ssi_value_length 256;
|
контекст:
|
http , server , location
|
Задаёт максимальную длину значений параметров в SSI-командах.
Команды SSI
Общий формат команд SSI такой:
<!--# команда параметр1=значение1 параметр2=значение2 ... -->
Поддерживаются следующие команды:
block
-
Описывает блок, который можно использовать
как заглушку в команде
include .
Внутри блока могут быть другие команды SSI.
Параметр команды:
name
-
имя блока.
Пример:
<!--# block name="one" -->
заглушка
<!--# endblock -->
config
-
Задаёт некоторые параметры, используемые при обработке SSI, а именно:
errmsg
-
строка, выводящаяся при ошибке во время обработки SSI.
По умолчанию выводится такая строка:
[an error occurred while processing the directive]
timefmt
-
строка формата, передаваемая функции
strftime()
для вывода даты и времени.
По умолчанию используется такой формат:
"%A, %d-%b-%Y %H:%M:%S %Z"
Для вывода времени в секундах подходит формат
“%s ”.
echo
-
Выводит значение переменной.
Параметры команды:
var
-
имя переменной.
encoding
-
способ кодирования.
Возможны три значения —
none , url и
entity .
По умолчанию используется entity .
default
-
нестандартный параметр, задающий строку, которая выводится,
если переменная не определена.
По умолчанию выводится строка
“
none ”.
Команда
<!--# echo var="name" default="нет" -->
заменяет такую последовательность команд:
<!--# if expr="$name" --><!--# echo var="name" --><!--#
else -->нет<!--# endif -->
if
-
Выполняет условное включение.
Поддерживаются следующие команды:
<!--# if expr="..." -->
...
<!--# elif expr="..." -->
...
<!--# else -->
...
<!--# endif -->
На данный момент поддерживается только один уровень вложенности.
Параметр команды:
expr
-
выражение.
В выражении может быть:
-
проверка существования переменной:
<!--# if expr="$name" -->
-
сравнение переменной с текстом:
<!--# if expr="$name = text " -->
<!--# if expr="$name != text " -->
-
сравнение переменной с регулярным выражением:
<!--# if expr="$name = /text /" -->
<!--# if expr="$name != /text /" -->
Если в text встречаются переменные,
то производится подстановка их значений.
В регулярном выражении можно задать позиционные и именованные выделения,
а затем использовать их через переменные, например:
<!--# if expr="$name = /(.+)@(?P<domain>.+)/" -->
<!--# echo var="1" -->
<!--# echo var="domain" -->
<!--# endif -->
include
-
Включает в ответ результат другого запроса.
Параметры команды:
file
-
задаёт включаемый файл, например:
<!--# include file="footer.html" -->
virtual
-
задаёт включаемый запрос, например:
<!--# include virtual="/remote/body.php?argument=value" -->
Несколько запросов, указанных на одной странице и обрабатываемых
проксируемыми или FastCGI-серверами, работают параллельно.
Если нужна последовательная обработка, следует воспользоваться параметром
wait .
stub
-
нестандартный параметр, задающий имя блока,
содержимое которого будет выведено, если тело ответа на включаемый запрос
пустое или если при исполнении запроса произошла ошибка, например:
<!--# block name="one" --> <!--# endblock -->
<!--# include virtual="/remote/body.php?argument=value" stub="one" -->
Содержимое замещающего блока обрабатывается в контексте включаемого запроса.
wait
-
нестандартный параметр, указывающий, нужно ли ждать
полного исполнения данного запроса, прежде чем продолжать выполнение
SSI, например:
<!--# include virtual="/remote/body.php?argument=value" wait="yes" -->
set
-
нестандартный параметр, указывающий, что удачный
результат выполнения запроса нужно записать в заданную переменную,
например:
<!--# include virtual="/remote/body.php?argument=value" set="one" -->
Необходимо учитывать, что в переменные можно записать только результаты
ответов, полученные через модули
ngx_http_proxy_module и
ngx_http_memcached_module.
set
-
Присваивает значение переменной.
Параметры команды:
var
-
имя переменной.
value
-
значение переменной.
Если в присваиваемом значении есть переменные,
то производится подстановка их значений.
Встроенные переменные
Модуль ngx_http_ssi_module поддерживает
две встроенные переменные:
$date_local
-
текущее время в локальной временной зоне.
Формат задаётся командой
config
с параметром timefmt .
$date_gmt
-
текущее время в GMT.
Формат задаётся командой
config
с параметром timefmt .
|