SELFHTML/Navigationshilfen Webserver/CGI Webserver | |
SSI - Server Side Includes |
|
Allgemeines zu Server Side Includes |
|
Mit Hilfe von Server Side Includes (auch unter der Abkürzung SSI bekannt) können Sie direkt innerhalb von HTML-Dateien dynamische Informationen, z.B. Datum und Uhrzeit, einbinden. Sie können auch CGI-Programme starten und deren Ausgaben, beispielsweise einen Zählerstand mit der Anzahl von Zugriffen auf die aktuelle Datei, in die HTML-Datei einbinden. Oder Sie geben den aktuellen Inhalt diverser CGI-Umgebungsvariablen direkt in HTML aus - ohne Umweg über ein separates CGI-Script. Server Side Includes sind generell dazu gedacht, kleinere Teile einer HTML-Seite dynamisch einzubinden.
Server Side Includes werden nur ausgeführt, wenn der Web-Browser die HTML-Datei über einen installierten Web-Server aufruft, also mit einem URI vom Typ http://.... Voraussetzung ist ferner, dass der installierte Web-Server die Server Side Includes unterstützt. Nicht alle Web-Server tun das, andere interpretieren nur einen Teil der möglichen Angaben. Wenn der Server keine Server Side Includes kennt, funktionieren die entsprechenden Anweisungen in der HTML-Datei nicht. Beim Austesten mit einem lokal installierten Web-Server lesen Sie hierzu bitte in der Dokumentation des Servers nach. Beim Einsatz auf einem öffentlichen Web-Server fragen Sie Ihren Provider, ob dessen Web-Server die Server Side Includes unterstützt.
Damit ein Web-Server sofort erkennt, ob eine HTML-Datei Server Side Include Anweisungen enthält, ist es üblich, solche HTML-Dateien mit einer speziellen Dateinamenendung zu kennzeichnen. Gewöhnlich lauten die Dateiendungen .shtml, .shtm oder .sht. Die meisten Server ignorieren Server Side Include Anweisungen, wenn diese in einer gewöhnlichen HTML-Datei mit der Endung .htm oder .html stehen!
Anzeigebeispiel: So sieht's aus (Zum Aufruf der Seite ist eine Internet-Verbindung erforderlich)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Dynamisches HTML mit Server Side Includes</title> </head> <body> <h1>Dynamisches HTML mit Server Side Includes</h1> Datum/Uhrzeit auf dem Server-Rechner: <!--#config timefmt="%d.%m.%Y, %H.%M" --> <!--#echo var="DATE_LOCAL" --> Uhr<br> Name dieser HTML-Datei: <!--#echo var="DOCUMENT_NAME" --><br> Installierte Server-Software: <!--#echo var="SERVER_SOFTWARE" --><br> Ihr Web-Browser: <!--#echo var="HTTP_USER_AGENT" --> <h3>Weitere Informationen:</h3> <!--#exec cgi="/cgi-bin/plapper.pl" --> </body> </html>
#!/usr/bin/perl -w print "Content-type: text/html\n\n"; print "<p>Aha, Sie haben das Script \"plapper.pl\" zusätzlich aufgerufen.<br>\n"; print "Das ist nett von Ihnen, aber es plappert gar nicht sehr viel.</p>\n";
Server Side Includes müssen Sie in einer HTML-Datei innerhalb eines Kommentars notieren. Es gibt verschiedene Server Side Include Anweisungen, beginnend mit einem Gatterzeichen #
. Im obigen Beispiel kommen die Anweisungen #echo
und #exec
vor. Hinter der Anweisung folgt in der Regel eine Angabe der Art Typ="Wert"
. Im Zusammenhang mit der Anweisung #echo
ist beispielsweise die Angabe var="Variablenname"
erlaubt, wobei "Variablenname" ein bestimmter, erlaubter Name sein muss. Es kann sich um Namen von CGI-Umgebungsvariablen handeln oder um spezielle Server Side Include Variablennamen (siehe Übersicht bekannter Server Side Includes weiter unten). Bei der Anweisung #exec
, die ein Programm auf dem Server-Rechner ausführt, müssen Sie den Typ des Programms (im obigen Beispiel: cgi
) und als Wert die Adresse des ausführbaren Programms (im obigen Beispiel: "/cgi-bin/plapper.pl"
) angeben.
Die Tabelle ist nach Anweisungen alphabetisch sortiert.
Anweisung | Parameter/Wert | Beispiele |
---|---|---|
#config |
Erlaubte Werte:
|
<!--#config errmsg="SSI nicht anzeigbar!" --> <!--#config sizefmt="bytes" --> <!--#config timefmt="%d.%m.%Y, %H.%M" -->
|
#echo |
Bei |
<!--#echo var="SERVER_NAME" --> <!--#echo var="DATE_LOCAL" -->
|
#exec |
Benutzen Sie |
<!--#exec cmd="/prog/search.exe *.htm" --> <!--#exec cgi="/cgi-bin/counter.pl" --> |
#fsize |
Gibt die Größe der angegebenen Datei aus. Verwenden Sie |
<!--#fsize virtual="/download/selfhtml.zip" -->
|
#flastmod |
Gibt den Zeitstempel der angegebenen Datei aus. Verwenden Sie |
<!--#flastmod file="/index.htm" -->
|
#include |
Gibt den Inhalt der angegebenen Datei aus. Verwenden Sie |
<!--#include virtual="/news/news.htm" -->
|
Findet der Webserver eine SSI-Anweisung, die er ausführen kann, so wird anstelle dieser Anweisung der angeforderte Code in das HTML-Dokument eingebunden. Wenn Sie nun mit
<!--#include virtual="datei.htm" -->
ein vollständiges HTML-Dokument einbinden, kann es Ihnen passieren, dass die "resultierende" Webseite plötzlich über mehrere Header-Bereiche verfügt und nicht mehr valides HTML ist. Moderne Browser (mit Ausnahme des Internet Explorer) könnten dadurch Anzeigeprobleme bekommen. Sie können das vermeiden, indem Sie Ihr *.shtml-Dokument völlig ohne HTML-Headerbereich ausstatten. Dann haben Sie aber nur die Möglichkeit, ein einziges HTML-Dokument mittels include file
einzubinden. Von dieser Möglichkeit machen Sie Gebrauch, wenn die einzubindende Datei nur über einen absoluten Pfad erreichbar ist.
Eleganter verfahren Sie, wenn die Datei, die Sie einbinden möchten, auf Ihrem eigenen Webspace verfügbar ist und selbst keine neuen HTML-Headerbereiche aufweist (müssen Sie einen absoluten Pfad nutzen, so lesen Sie die entsprechende Datei einfach mit einem CGI-(Perl-)Script ein, speichern das Eingelesene temporär und lassen mit dem Script den HTML-Kopfbereich entfernen). Dafür wird gelegentlich empfohlen, die Dateinamenserweiterung inc
zu verwenden, also beispielsweise dateiname.inc. Solche inc
-Dateien sollten reine Textdateien sein und dürfen jeden beliebigen HTML-Code enthalten - eben mit Ausnahme der HTML-Kopfdaten. Alles, was Sie sonst innerhalb von <body>
und </body>
notiert haben, kann in solchen Dateien enthalten sein - auch <script ...>
-Bereiche oder weitere SSI-Anweisungen.
Sie können beliebig viele SSI-Anweisungen in einer *.shtml-Datei notieren. Der Webserver setzt aus den angeforderten Daten ein neues HTML-Dokument zusammen und der Benutzer, der Ihr *.shtml-Dokument in seinem Browser aufruft, erfährt nichts davon, wie es zusammengesetzt wurde. Gehen Sie daher besonders mit
<!--#include virtual="datei.inc" -->
sorgsam um. Wenn Sie sehr viele HTML-Codeschnipsel auf diese Weise einbinden, wird das resultierende HTML-Dokument unter Umständen sehr groß.
Mit SSI können Sie noch wesentlich mehr anstellen als oben beschrieben. Sie haben an der Bezeichnung var
weiter oben bereits ablesen können, dass Sie Variablen verwenden dürfen. Selbstverständlich können Sie anstelle von festgelegten Umgebungsvariablen wie SERVER_NAME
oder DATE_LOCAL
auch eigene Variablen definieren. Das Apache-Modul mod_include
, das die Ausführung von SSI überhaupt erst ermöglicht, stellt dafür so etwas wie eine winzige Programmiersprache zur Verfügung. So können Sie beispielsweise mit
set var="name" value="Wert"
einer Variablen einen beliebigen Namen geben und ihr einen beliebigen Wert zuweisen. Es ist ebenfalls möglich, mit einfachen if/else
-Festlegungen Bedingungen zu formulieren, die für das Ausführen bestimmter Server Side Includes zutreffen sollen.
Anzeigebeispiel 1: So sieht's aus (ohne Übergabeparameter) (Zum Aufruf der Seite ist eine Internet-Verbindung erforderlich)
Anzeigebeispiel 2: So sieht's aus (mit Übergabeparameter) (Zum Aufruf der Seite ist eine Internet-Verbindung erforderlich)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Dynamisches HTML mit Server Side Includes</title> </head> <body> <h1>Dynamisches HTML mit Server Side Includes</h1> <p>Diese Seite hat keine festgelegten Inhalte, sondern wird vom Server zusammengesetzt.<p> <!--#if expr="$QUERY_STRING = /test/" --> <!--#set var="param" value="Sie haben die Seite mit dem test-Parameter aufgerufen" --> <!--#echo var="param" --> <!--#else --> <!--#include virtual="test.inc" --> <!--#endif --> </body> </html>
<p>Auf einer Meierei,<br> da lebte einst ein braves Huhn,<br> das legte, wie die Hühner tun,<br> an jedem Tag ein Ei.<br> Und kakelte, mirakelte, spektakelte,<br> als obs ein Wunder sei.</p>
Die Beispieldatei test2.shtml enthält insgesamt sechs Zeilen mit SSI-Anweisungen.
In der erten Anweisung fragen Sie ab, ob der aufgerufenen URL ein Parameter in der Form test2.shtml?test mitgegeben wurde. Den Namen dieses Parameters müssen Sie in Slashes (Schrägstriche) einfassen, das entspricht ungefähr dem, was Sie von Perl als regulären Ausdruck kennen. Trifft dies zu, wird in der zweiten Zeile der Variablenname param
festgelegt und die Variable erhält gleichzeitig einen String (den Satz:"Sie haben die Seite mit dem test-Parameter aufgerufen") als Wert zugewiesen.
In der dritten Anweisung geben Sie mit echo
(auch wieder ähnlich dem Perl-Befehl) den Wert der Variablen param
am Bildschirm aus.
Die vierte Anweisung legt fest, dass es eine Alternative geben soll, falls Sie die URL nicht mit einem zusätzlichen Parameter aufgerufen haben.
Die fünfte Anweisung veranlasst den Webserver, an dieser Stelle den gesamten Inhalt der Datei test.inc einzubinden.
Mit der letzten Zeile wird die if/else-Bedingung beendet. Eine solche abschließende Zeile müssen Sie immer angeben.
Mit dem Einsatz von Variablen in SSI-Anweisungen können Sie die Erscheinungsweise Ihrer Webseite auf vielfältige Weise variieren. Beispielsweise können Sie von Übergabe-Parametern abhängig machen, ob bestimmte Links angezeigt oder ganze Textblöcke überhaupt in die Seite aufgenommen werden sollen. Sie können mehrere Parameter miteinander kombinieren und sich damit ein dynamisches Navigationsmenü zusammenstellen. Sie können den anzuzeigenden Inhalt komplett austauschen lassen usw.
Server Side Includes stellen keine Alternative zu dem dar, was Scriptsprachen wie Perl oder PHP an Möglichkeiten anbieten. Mit SSI können Sie bestehende Dateien nicht verändern, Sie können nichts speichern, nur in geringem Umfang Formulardaten berücksichtigen, keine Berechnungen ausführen lassen und vieles weitere. Aber für die "dynamische" Zusammenstellung von Seiteninhalten bieten SSI einige großartige Perspektiven an, und Sie müssen sich nicht erst mit den oftmals komplexen Programmiertechniken der "großen" Scriptsprachen befassen.
.htaccess - Server-Reaktionen kontrollieren | |
Der Apache HTTP-Webserver | |
SELFHTML/Navigationshilfen Webserver/CGI Webserver |
© 2005 Impressum