Installation auf Windows Systemen

Dieser Teil behandelt Windows 95/98/Me und Windows NT/2000/XP (Das Setup auf XP ist dzt. noch nicht getestet). Erwarten Sie nicht, dass PHP auf 16 Bit-Plattformen, wie z.B. Windows 3.1 läuft. Manchmal sprechen wir bei den unterstützten Plattformen von Win32.

Es gibt zwei Wege PHP für Windows zu installieren: entweder manuell, oder mittels dem InstallShield Installer.

Wenn Sie Microsoft Visual Studio besitzen, können Sie auch den Source Code von PHP selbst kompilieren.

Haben Sie PHP erst einmal auf Ihrem Windows System installiert, können Sie als Erweiterung der Funktionalität auch verschiedene Erweiterungen laden.

Windows InstallShield

Der von der Downloadseite auf http://www.php.net/ erhältliche Windows PHP Installer installiert die CGI Version von PHP, und konfiguriert auch die Webserver IIS, PWS, und Xitami. Beachten Sie aber auch, dass der InstallShield Installer zwar eine einfache Art der Installation von PHP ist, gleichzeitig aber auch in verschiedenen Aspekten eingeschränkt ist (z.B. wird ein automatisches Setup von Erweiterungen nicht unterstützt).

Installieren Sie Ihren gewünschten HTTP Server auf Ihrem System und stellen Sie sicher, dass er läuft.

Starten Sie nun das Installationsprogramm, und folgen Sie den Instruktionen des Installation Wizards. Es werden zwei Installationsarten unterstützt: Standard bietet zweckmäßige Standardeinstellungen wo dies möglich ist, und Advanced (erweitert), welche die gewünschten Einstellungen während der Installation abfragt.

Der Installation Wizard sammelt genug Informationen, um die php.ini zu erstellen, und den Webserver für den Einsatz von PHP zu konfigurieren. Für IIS und auch PWS auf Windows NT Workstation wird eine Liste mit den Knoten auf dem Server, sowie eine Liste mit den Script Mappings angezeigt aus welcher Sie die gewünschten Knoten auswählen können, auf denen PHP in die Script Mappings eingetragen werden soll.

Wenn die Installation fertig ist informiert Sie der Installer, ob Sie Ihr System oder den Server neu starten sollen, oder ob Sie einfach mit der Nutzung von PHP beginnen können.

Warnung

Seien Sie sich darüber im Klaren, dass dieses Setup von PHP nicht sicher ist. Wenn Sie ein sicheres Setup von PHP möchten, Setzen Sie PHP manuell auf, und wählen jede Option sorgfältig aus. Dieses automatische Setup bietet Ihnen eine sofort lauffähige PHP Installation, ist jedoch nicht für den Einsatz auf Online-Servern gedacht.

Manuelle Installationsschritte

Diese Installationsanleitung hilft Ihnen, PHP auf Ihrem Windows Webserver manuell zu installieren und zu konfigurieren. Laden Sie sich hierfür bitte die gezippte Distribution von der Downloadseite http://www.php.net/ herunter. Die Originalversion dieser Anleitung wurde von Bob Silva verfasst, welche Sie auf http://www.umesd.k12.or.us/php/win32install.html finden.

Diese Anleitung unterstützt Sie bei der manuellen Installation für:

PHP 4 für Windows gibt es in zwei Varianten - ein CGI Modul (php.exe), und verschiedene SAPI Module (z.B. php4isapi.dll). Letztere ist neu in PHP 4, und bietet eine signifikant höhere Performance, sowie neue Funktionalitäten.

Warnung

Beachten Sie bitte, dass die Qualität der SAPI Module für den Einsatz auf Produktionsservern dzt. als noch NICHT hoch genug eingestuft wird. Besonders beim ISAPI Modul können speziell auf älteren Plattformen als W2k ernsthafte Stabilitätsprobleme auftreten - Sie könnten z.B. einige Server 500 Errors erleben, und am Ausfall anderer Servermodule wie ASP leiden. Sie wurden gewarnt!

Der Grund dafür ist, dass die PHP SAPI Module die Thread-safe Version des PHP Codes nutzen. Diese ist neu in PHP 4, und wurde noch nicht eingehend genug getestet und belastet, um als völlig stabil angesehen werden zu können, und es sind dzt. auch ein paar Fehler bekannt. Andererseits haben einige Leute über sehr gute Resultate mit den SAPI Modulen berichtet, auch wenn wir über niemanden informiert sind, der sie auf Produktionsservern einsetzt. Kurz gesagt - Ihr Nutzen kann variieren; Wenn Sie absolute Stabilität benötigen, tauschen Sie die Performance der SAPI Module gegen die Stabilität des CGI Moduls.

Wenn Sie eines der SAPI Module unter Windows 95 einsetzen möchten, holen Sie sich das DCOM Update von den Microsoft DCOM Seiten. Für das ISAPI Modul wird ein ISAPI 4.0 kompatibler Webserver benötigt (getestet wurden IIS 4.0, PWS 4.0 und IIS 5.0). IIS 3.0 wird NICHT unterstützt. Wenn Sie gediegene PHP Unterstützung wünschen, sollten Sie In diesem Fall den Windows NT 4.0 Option Pack mit IIS 4.0 downloaden.

Die folgenden Schritte sollten vor den serverspezifischen Instruktionen an allen Installationen durchgeführt werden.

Den Source kompilieren

Bevor wir beginnen lohnt es sich, folgende Frage zu beantworten: "Warum ist das Kompilieren unter Windows so schwer?" Zwei Gründe drängen sich auf:

  1. Windows genießt (noch) keine große Gemeinschaft von Entwicklern welche auch bereit sind, deren Sourcecode frei zur Verfügung zu stellen. Als Ergebnis wurden die nötigen Investitionen in die für solche Entwicklungen nötige Infrastruktur nicht getätigt. Das meiste was verfügbar ist, wurde durch die Portierung der nötigen Werkzeuge von Unix möglich gemacht. Seien Sie deshalb nicht überrascht, wenn manches aus diesem Erbe von Zeit zu Zeit durchscheint.

  2. Fast alle der folgenden Instruktionen sind von der Art "Einstellen und vergessen". Deshalb lehnen Sie sich zurück, und folgen den nachstehenden Instruktionen so gewissenhaft Sie können.

Vorbereitungen

Bevor Sie beginnen können, müssen Sie einiges downloaden...

  • Erst einmal benötigen Sie den Cygwin Toolkit von einem Cygwin Mirror in Ihrer Nähe. Cygwin bietet die meisten der populären GNU Utilities, welche während der Kompilation benötigt werden.

  • Laden Sie den Rest der benötigten Tools von der PHP Seite http://www.php.net/extra/win32build.zip herunter.

  • Laden Sie sich auch den Sourcecode für die von PHP verwendete DNS Namensauflösung von http://www.php.net/extra/bindlib_w32.zip herunter. Dieser ersetzt die in win32build.zip enthaltene Bibliothek resolv.lib.

  • Sollten Sie noch kein Tool zur dekomprimierung besitzen, so bekommen Sie eine freie Version von InfoZip.

Als letztes benötigen Sie natürlich den Sourcecode von PHP 4 selbst. Sie bekommen die aktuellste Entwicklerversion unter Verwendung des anonymen CVS. Wenn Sie einen Snapshot oder einen Source Tarball downloaden, müssen Sie ihn nicht nur erst dekomprimieren, sondern auch in den *.dsp und *.dsw Dateien die einfachen Linefeeds in crlf konvertieren, bevor diese von Microsoft Visual C++ geladen werden.

Anmerkung: Stellen Sie die Verzeichnisse Zend und TSRM in das php4 Verzeichnis, damit die Projekte während des Kompilierens gefunden werden.

Alles zusammenfügen

  • Folgen Sie den Anweisungen zur Installation des von Ihnen gewählten Dekomprimierungstools.

  • Führen Sie setup.exe aus, und folgen Sie den Installationsanweisungen. Wenn Sie einen anderen Pfad als c:\cygnus wählen, setzen Sie bitte die Cygwin Environmentvariable. Unter Windows 95/98 kann dies mittels einer Zeile in der autoexec.bat erfolgen. Unter Windows NT gehen Sie auf Systemsteuerung => System und wählen den Tab Umgebungsvariablen aus.

    Warnung

    Erstellen Sie ein temporäres Verzeichnis für Cygwin, sonst werden einige Kommandos (speziell bison) nicht korrekt ausgeführt. Unter Windows 95/98, mkdir C:\TMP. Für Windows NT, mkdir %SystemDrive%\tmp.

  • Erstellen Sie ein Verzeichnis, und dekomprimieren Sie darin win32build.zip.

  • Starten Sie Microsoft Visual C++, und wählen im Menü Extras => Optionen => Verzeichnisse. Wechseln Sie nacheinander zu "Ausführbare Dateien", "Include Dateien" und "Bibliothek Dateien", und vergewissern Sie sich, dass cygwin\bin, win32build\include, und win32build\lib in der jeweiligen Liste eingetragen sind (Um einen Eintrag hinzuzufügen, wählen Sie eine leere Zeile am Ende der Liste aus, und beginnen einzutippen). Typische Einträge sehen wie folgt aus:

    • c:\cygnus\bin

    • c:\php-win32build\include

    • c:\php-win32build\lib

    Drücken Sie OK, und verlassen Sie Visual C++.

  • Erstellen Sie ein anderes Verzeichnis, und dekomprimieren Sie darin bindlib_w32.zip. Entscheiden Sie sich, ob Sie die Debug-Symbole verfügbar haben wollen (bindlib - Win32 Debug) oder nicht (bindlib - Win32 Release). Erstellen die geeignete Konfiguration:

    • Wenn Sie das GUI benutzen: Starten Sie VC++, selektieren Sie Datei => Arbeitsbereich öffnen, und wählen Sie bindlib aus. Dann selektieren Sie Build => Aktive Konfiguration, und wählen die gewünschte Konfiguration aus. Letztendlich wählen Sie Erstellen => Rebuild All.

    • Wenn Sie die Kommandozeile benutzen stellen Sie sicher, dass die C++ Environmentvariablen registriert sind, oder starten Sie vcvars.bat, und führen eines der folgenden Kommandos aus:

      • msdev bindlib.dsp /MAKE "bindlib - Win32 Debug"

      • msdev bindlib.dsp /MAKE "bindlib - Win32 Release"

    • Nun sollten Sie entweder in Ihrem Debug oder Release Verzeichnis eine verwendbare resolv.lib haben. Kopieren Sie diese Datei in Ihr win32build\lib Verzeichnis, und überschreiben damit die dort bereits vorhandene Datei mit dem gleichen Namen.

Kompilieren

Der einfachste Weg zu beginnen, ist die standalone/CGI Version zu erstellen.

  • Wenn Sie das GUI benutzen: Starten Sie VC++, selektieren Sie Datei => Arbeitsbereich öffnen, und wählen Sie php4ts aus. Dann selektieren Sie Erstellen => Setze aktuelle Konfiguration, und wählen die gewünschte Konfiguration aus. Letztendlich wählen Sie Erstellen => Rebuild All.

  • Wenn Sie die Kommandozeile benutzen stellen Sie sicher, dass die C++ Environmentvariablen registriert sind, oder starten Sie vcvars.bat, und führen eines der folgenden Kommandos aus:

    • msdev php4ts.dsp /MAKE "php4ts - Win32 Debug_TS"

    • msdev php4ts.dsp /MAKE "php4ts - Win32 Release_TS"

    • Nun sollten Sie entweder in Ihrem Debug_TS oder Release_TS Verzeichnis eine verwendbare php.exe haben.

Wiederholen Sie die obigen Schritte mit php4isapi.dsp (welches sich in sapi\isapi befindet), um das für eine Integration mit Microsoft IIS nötige ISAPI-Modul zu erstellen.

Installation von Windows Erweiterungen

Sind PHP und ein Webserver einmal auf Windows installiert, möchten Sie vielleicht einige Erweiterungen für zusätzliche Funktionalität installieren. Die folgende Tabelle beschreibt einige der verfügbaren Erweiterungen. Sie können Erweiterungen auswählen, welche beim Start von PHP geladen werden, indem Sie das Kommentarzeichen (';') in den entsprechenden 'extension=php_*.dll' Zeilen in der php.ini entfernen. Sie können Module mittels dl() auch dynamisch laden.

Die DLLs für PHP Erweiterungen enthalten in PHP 4 als Präfix 'php_' (und 'php3_' in PHP 3), um Verwechslungen zwischen PHP Erweiterungen und deren unterstützenden Bibliotheken zu vermeiden.

Anmerkung: In PHP 4.0.6 ist die Unterstützung für BCMath, Calendar, COM, FTP, MySQL, ODBC, PCRE, Session, WDDX und XML inkludiert. Um diese Funktionen zu benutzen, brauchen Sie keine zusätzlichen Erweiterungen zu laden. Eine Liste mit den bereits inkludierten Modulen befindet sich in der README.txt oder install.txt Ihrer Distribution.

Anmerkung: Einige Erweiterungen benötigen externe DLLs, wovon bereits einige im Verzeichnis 'dlls' der PHP Distribution enthalten sind. Manche Erweiterungen benötigen jedoch DLLs, welche nicht in der PHP Distribution enthalten sind, wie z.B. Oracle (php_oci8.dll).

Kopieren Sie die DLLs vom Verzeichnis 'dlls' in Ihren Windows PATH, gute Plätze sind:

c:\windows\system für Windows 9x/ME
c:\winnt\system32 für Windows NT/2000

Sollten diese Dateien bereits auf Ihrem System installiert sein, überschreiben Sie diese nur, wenn etwas nicht korrekt läuft (Vor dem Überschreiben empfehlen wir ein Backup, oder verschieben diese Dateien in ein anderes Verzeichnis - nur für den Fall dass etwas schiefgeht).

Tabelle 3-1. PHP Erweiterungen

ErweiterungBeschreibungAnmerkungen
php_bz2.dllbzip2 compression functionsKeine
php_calendar.dllKalender UmwandlungsfunktionenIst seit PHP 4.0.3 integriert
php_cpdf.dllClibPDF FunktionenKeine
php3_crypt.dllVerschlüsselungsfunktionenKeine
php_ctype.dllctype FunktionenKeine
php_curl.dllCURL, Client URL BibliotheksfunktionenBenötigt libeay32.dll, ssleay32.dll (bundled)
php_cybercash.dllCybercash Zahlungssystem FunktionenKeine
php_db.dllDBM FunktionenNicht empfohlen. Verwenden Sie stattdessen DBA (php_dba.dll)
php_dba.dllDBA Datenbank (dbm-style) Abstraktions-FunktionenKeine
php_dbase.dlldBase FunktionenKeine
php3_dbm.dllBerkeley DB2 BibliothekKeine
php_domxml.dllDOM XML FunktionenBenötigt libxml2.dll (bundled)
php_dotnet.dll.NET FunktionenKeine
php_exif.dllLiest EXIF Headers einer JPEG-GrafikKeine
php_fbsql.dllFrontBase FunktionenKeine
php_fdf.dllFDF: Forms Data Format FunktionenBenötigt fdftk.dll (bundled)
php_filepro.dllfilePro FunktionenRead-only Zugriff
php_ftp.dllFTP FunktionenIst seit PHP 4.0.3 integriert
php_gd.dllGDGD Bibliotheksfunktionen zur BildmanipulationKeine
php_gettext.dllGettext FunktionenBenötigt gnu_gettext.dll (bundled)
php_hyperwave.dllHyperWave FunktionenKeine
php_iconv.dllICONV ZeichensatzumwandlungBenötigt iconv-1.3.dll (bundled)
php_ifx.dllInformix FunktionenBenötigt Informix Bibliotheken
php_iisfunc.dllIIS ManagementfunktionenKeine
php_imap.dllIMAP POP3 und NNTP FunktionenPHP 3: php3_imap4r1.dll
php_ingres.dllIngres II FunktionenBenötigt Ingres II Bibliotheken
php_interbase.dllInterBase FunktionenBenötigt gds32.dll (bundled)
php_java.dllJava ErweiterungBenötigt jvm.dll (bundled)
php_ldap.dllLDAP FunktionenBenötigt libsasl.dll (bundled)
php_mhash.dllMhash FunktionenKeine
php_ming.dllMing Funktionen für FlashKeine
php_msql.dllmSQL FunktionenBenötigt msql.dll (bundled)
php3_msql1.dllmSQL 1 ClientKeine
php3_msql2.dllmSQL 2 ClientKeine
php_mssql.dllMSSQL FunktionenBenötigt ntwdblib.dll (bundled)
php3_mysql.dllMySQL Funktionenin PHP 4 bereits integriert
php3_nsmail.dllNetscape Mail FunktionenKeine
php3_oci73.dllOracle FunktionenKeine
php_oci8.dllOracle 8 FunktionenBenötigt Oracle 8 Client Bibliotheken
php_openssl.dllOpenSSL FunktionenBenötigt libeay32.dll (bundled)
php_oracle.dllOracle FunktionenBenötigt Oracle 7 Client Bibliotheken
php_pdf.dllPDF FunktionenKeine
php_pgsql.dllPostgreSQL FunktionenKeine
php_printer.dllPrinter FunktionenKeine
php_sablot.dllXSLT FunktionenBenötigt sablot.dll (bundled)
php_snmp.dllSNMP get and walk Funktionennur NT!
php_sybase_ct.dllSybase FunktionenBenötigt Sybase Client Bibliotheken
php_yaz.dllYAZ FunktionenKeine
php_zlib.dllZLib KomprimierungsfunktionenKeine