このモジュールはファイルがクライアントに送られる前に処理するフィルタを 提供します。処理の内容は要素と呼ばれる特別な形式の SGML コメントにより 制御されます。これらの要素は条件分岐や、他のファイルや プログラムの出力の取り込み、環境変数の設定や表示を行なうことが できます。
Server Side Includes は INCLUDES
フィルタ により実装されています。
Server-side include のディレクティブを含むドキュメントの拡張子が
.shtml の場合、以下のディレクティブでは Apache がそれらを
パースして、その結果できるドキュメントに text/html
の
MIME タイプを割り当てます:
以下のディレクティブは shtml ファイルのあるディレクトリで指定されている
必要があります (通常は Options
が設定されていると、.htaccess
ファイルに書くこともできます):
互換性を保つために、server-parsed
ハンドラ も INCLUDES フィルタを
有効にします。MIME タイプ text/x-server-parsed-html
や
text/x-server-parsed-html3
のドキュメントに対しても
Apache は INCLUDES フィルタを有効にします (出力されるものは
MIME タイプ text/html
になります)。
詳しい情報は Tutorial on Server Side Includes.
SSI で処理されるファイルはデフォルトでは PATH_INFO
(後続のパス名情報)
付きのリクエストを受け入れなくなりました。PATH_INFO
付きのリクエストを受け入れるようにサーバを
設定できます。
ドキュメントは、SGML のコメントとして特別なコマンドが埋め込まれた HTML ドキュメントとしてパースされます。コマンドの構文は次のように なっています:
値 (訳注: value) は二重引用符で囲むのが一般的ですが、
シングルクオート (') とバッククオート (`) も使用できます。
多くのコマンドは属性-値 (訳注: attribute-value) の組を一つだけ指定できます。
コメントの終わり (-->
)
の前には、SSI の句の一部だと解釈されないようにするために空白を
入れてください。最初の <!--#
はまとめて一つの
句で、空白をふくんではいけないこと注意してください。
要素 (訳注: element) を以下の表に示します。
要素 | 説明 |
---|---|
config |
configure output formats |
echo |
print variables |
exec |
execute external programs |
fsize |
print size of a file |
flastmod |
print last modification time of a file |
include |
include a file |
printenv |
print all available variables |
set |
set a value of a variable |
SSI 要素は exec
要素は
次のコマンドは解析の様々な側面を制御します。属性は次の通りです。
echomsg
(Apache 2.1 以降)echo
要素が未定義の変数をエコーしようとした際に、
クライアントに送られるメッセージになります。
errmsg
sizefmt
bytes
か、Kb や Mb を優先的に使用する
abbrec
(例えば 1024 バイトは "1K" と表示されます)
です。timefmt
strftime(3)
ライブラリルーチンが
日時をプリントする際に用いられます。このコマンドは以下で定義されている include
変数 を表示します。変数が設定されていない場合は timefmt
に従って
表示されます。属性は次の通りです。
var
encoding
変数を出力する前に、変数中の特別文字をどのようにエンコードするかを
指定します。none
に設定されていると、エンコードは行なわれません。
url
に設定されていると、URL エンコード (%-エンコードとも
呼ばれています。これはリンク等の URL の使用に適切です) が
行なわれます。echo
要素の開始時は、デフォルトは
entity
に設定されています。これはエンティティエンコード
(段落やテキストなどのブロックレベルの HTML エレメントのコンテキストに
適しています) を行ないます。これは encoding
属性
を加えることで変更できます。変更は次の encoding
属性か、
要素の終了まで効力を持ちます。
encoding
属性はエンコードの変更をしたい var
の前に ある必要があることに注意してください。
また、ISO-8859-1 エンコーディングで
定義されている特別な文字だけがエンコードされます。
別の文字のエンコーディングの場合は、このエンコーディングは
望みの結果にならないかもしれません。
exec
コマンドは指定されたシェルコマンドや CGI スクリプトを
実行します。IncludesNOEXEC
はこのコマンドを無効にします。
使用可能な属性は次の通りです。
cgi
値は (%-エンコードされた) URL を指定します。パスが
スラッシュ (/) で始まらないときは、ドキュメントからの
相対パスとして扱われます。このパスで参照されているドキュメントは
サーバが CGI スクリプトとして扱っていなくても CGI スクリプトとして
起動されます。ただし、スクリプトのあるディレクトリでは
(ExecCGI
によって) CGI スクリプトの使用が許可されている必要があります。
CGI スクリプトには、クライアントからの元々のリクエストの
PATH_INFO
とクエリー文字列 (QUERY_STRING
) が渡されます。
これらは URL パスとして特定できないものです。
スクリプトは標準 CGI 環境に加えて、include 変数を
使用することができます。
スクリプトが、出力の代わりに Location:
ヘッダを返すと、
HTML のアンカー (訳注:リンク) に変換されます。
exec cgi
よりも、
include virtual
の方を使うようにしてください。特に、CGI への追加の引数を
クエリー文字列を使って渡すことは exec cgi
は
できませんが、include virtual
は以下のようにして
可能です。
cmd
サーバは指定された文字列を /bin/sh
を使って
実行します。コマンドは通常の CGI 変数に加えて include 変数も使うことができます。
ほとんどの場合、#include
virtual
を使う方が #exec cgi
や #exec
cmd
を使うよりも良いです。前者 (#include virtual
)
は標準の Apache のサブリクエスト機構を使ってファイルやスクリプトの
出力を取り込みます。
こちらの方がよくテストされメンテナンスされた方法です。
さらに、Win32 のようないくつかのプラットフォームや、suexec を使っている unix では、
exec
ディレクティブのコマンドに
引数を渡したり、コマンドに空白を入れることはできません。
ですから、以下のものは unix の suexec でない設定では動作しますが、
Win32 や suexec を使っている unix では期待した結果にはなりません:
このコマンドは指定されたファイルの大きさを sizefmt
の
書式指定に基づいて出力します。属性は次の通りです。
file
virtual
このコマンドは指定されたファイルの最終修正時刻を
timefmt
書式指定に従って表示します。
指定可能な属性は fsize
コマンドと同じです。
このコマンドは別の文書やファイルのテキストを解析しているファイルに
挿入します。挿入されるファイルはアクセス制御の管理下にあります。
解析しているファイルの存在するディレクトリに
Option IncludesNOEXEC
が設定されている場合、text MIME タイプ (text/plain
,
text/html
等) のドキュメントのみインクルードが行なわれます。
その他の場合は、クエリー文字列も含め、コマンドで指定された
完全な URL を使って普通に CGI スクリプトが呼び出されます。
属性が文書の位置を指定します。include コマンドに与えられたそれぞれの 属性に対して挿入作業が行なわれます。有効な属性は次の通りです。
file
../
を含んでいたり、絶対パスを指定したりはできません。
ですから、ドキュメントルートの外にあるファイルや、ディレクトリ構造で
上位にあるファイルを挿入することはできません。
常にこの属性よりは、virtual
属性を使うようにしてください。
virtual
値は解析されているドキュメントからの (% エンコードされた) URL です。URL にはスキームやホスト名を含めることはできません。パスと、 もしあればクエリー文字列を指定できるだけです。スラッシュ (/) から 始まらない場合は、ドキュメントからの相対パスとして扱われます。
URL は属性から作られ、その URL をクライアントがアクセスしたときに 出力される内容が解析後の出力に含められます。ですから、挿入される ファイルは入れ子構造にすることができます。
指定された URL が CGI プログラムであった場合は、 プログラムが実行され、その出力が解析しているファイル中の ディレクティブがあった位置に挿入されます。CGI の url に クエリー URL を入れることもできます。
HTML ドキュメントに CGI プログラムの出力を含める方法としては、
include virtual
の方が exec cgi
よりも
好ましい方法です。
これは、存在するすべての変数とその値を表示します。Apache 1.3.12 から、
特別な文字は出力される前にエンティティエンコード (詳細は echo
要素を参照)
されるようになりました。属性はありません。
これは変数の値を設定します。属性は次の通りです。
var
value
標準 CGI 環境の変数に加えて、echo
コマンドや、
if
や elif
, それにドキュメントから呼び出される
すべてのプログラムから使用できる変数があります。
DATE_GMT
DATE_LOCAL
DOCUMENT_NAME
DOCUMENT_URI
LAST_MODIFIED
QUERY_STRING_UNESCAPED
&
といった特殊文字にはバックスラッシュが直前に置かれます)。変数置換はたいていの場合 SSI ディレクティブの引数として妥当な場所にある
引用符で囲まれた文字列中で行なわれます。これに該当するものには、
config
,
exec
, flastmod
, fsize
,
include
, echo
, set
の
各ディレクティブと、条件分岐用のオペレータへの引数があります。
ドル記号はバックスラッシュを使うことで使うことができます:
変数名としてみなされる文字列の中で変数への参照を置換する必要があるときは、 シェルでの変数置換のように、中括弧で括ることで区別することができます:
この例では、REMOTE_HOST
が
"X
" で REQUEST_METHOD
が
"Y
" のときに変数 Zed
を "X_Y
"
に設定します。
以下の例では、DOCUMENT_URI
が /foo/file.html
のときに "in foo" を、/bar/file.html
のときに "in bar" を、
どちらでもないときには "in neither" を表示します。
基本的なフローコントロール要素は次の通りです。
if
要素はプログラミング言語の
if 文と同じように動作します。条件が評価され、結果が真であれば次の
elif
か else
か endif
要素までの文字列が出力に挿入されます。
elif
や else
文は test_condition
が偽のときにテキストを出力に挿入するために使われます。
これらの要素はあってもなくても構いません。
endif
要素は if
要素を終了させます。この要素は必須です。
test_condition は以下のどれかです:
string
string1 = string2
string1 == string2
string1 != string2
string1 と string2 を比較します。
string2 が /string/
という形式であれば、正規表現として比較されます。正規表現は
PCRE エンジンで実装されていて、
perl 5 と同じ構文を使用します。
==
は単に =
の別名で、まったく同じ動作を
します。
正のマッチング (=
または ==
) の場合は、
正規表現でグループ分けされたパーツをキャプチャすることができます。
キャプチャされた部分は特殊変数 $1
.. $9
に格納されます。
string1 < string2
string1 <= string2
string1 > string2
string1 >= string2
strcmp(3)
を使用)
ことに注意してください。ですから、文字列 "100" は "20"
よりも小さいことになります。( test_condition )
! test_condition
test_condition1 &&
test_condition2
test_condition1 ||
test_condition2
"=" と "!=" の方が "&&" より きつく束縛します。"!" の束縛が一番きつくなっています。 ですから以下の二つは等価です:
真偽値オペレータ &&
と ||
は同じ優先度です。
これらのオペレータで一方により強い優先度をつけたい場合には、
括弧を使う必要があります。
変数やオペレータとして認識されないものはすべて文字列として
扱われます。文字列は引用符で囲むこともできます: 'string'
のように。引用符で囲まれていない文字列には空白 (スペースとタブ)
を含めることはできません。それらは変数などの句を分離するために
使われているからです。複数の文字列が続いているときは、
空白を間に入れて一つにくっつけられます。ですから、
string1 string2
は string1 string2
になります。
また、
'string1 string2'
は string1 string2
になります。
式がもっと複雑になり、処理の速度低下が顕著になった場合は、 評価ルールに従って最適化してみると良いでしょう。
&&
と ||
)
は、出来る限り短絡評価されます。つまり結果として上記のルールは、
$1
.. $9
)
を埋めるために、実際に評価する必要があるからです。特定の式がどのように扱われるかを知りたい場合は、
-DDEBUG_INCLUDE
コンパイラオプションを付けて
このディレクティブは
このディレクティブは変数が定義されていないにも関わらず
"echo" されたときに
"<!-- Error -->"
に変えるというようなことを考えるかもしれません。
このディレクティブは <!--#config
errmsg=message -->
要素と同じ効果になります。
このディレクティブは
二つのサーバで (もしかすると別々の段階で) ファイルの出力を解析していて、 それぞれに違うコマンドを処理させたい、 というようなときにこのオプションを使います。
上の例のように対応する
このディレクティブは DATE
環境変数を echo して日付を現す文字列が
表示されるときの書式を変更します。formatstring は
C 標準ライブラリの strftime(3)
と同じ形式です。
このディレクティブは <!--#config
timefmt=formatstring -->
要素と同じ効果になります。
上のディレクティブでは、日付は "22:26, June 14, 2002" という 形式で表示されます。
text/html
と関連付けられているファイルにのみ影響します。
off
on
text/html
ファイルは全てサーバで解析する html ドキュメントとして扱われます。full
on
と同様ですが、グループ実行ビットもテストします。
もしそれが設定されていれば、返されるファイルの Last-modified
の
日付をファイルの最終修正時刻にします。それが設定されていないときは、
last-modified の日付は送られません。このビットを設定すると、
クライアントやプロキシがリクエストをキャッシュできるようになります。
#include
するかもしれないものや、各アクセスに対して違う出力を生成する
(もしくは後のリクエストで変わるかもしれないもの)
すべての SSI スクリプトに対してグループ実行ビットが
設定されていないことを確認できない場合は、full は使わない方が良い
でしょう。