Nachtrag JavaScript Benutzer-Verzeichnisse MIME

Transcription

Nachtrag JavaScript Benutzer-Verzeichnisse MIME
3.1.1 Webserver: Installation und Konfiguration
Nachtrag JavaScript
Benutzer-Verzeichnisse
Vererbung Konstruktor, zwei Möglichkeiten
Private Funktionen: kein Zugriff auf this – Hilfskonstruktion notwendig
Typisierte Vergleiche mit === bzw. !==
Öffentliche Eigenschaften/Methoden von Objektschablonen können
von außen für alle Instanzen oder für eine bestimmte Instanz
überschrieben/erweitert werden.
Barrierefreiheit: Hinzuzufügender Inhalt nicht knotenweise, sondern
auf einen Schlag in das Dokument einfügen.
Gliederung der Dokumente nach Benutzern
z.B. für persönliche Homepages
Aufruf der Startseite mit ~Username
z.B. http://www.fbi.h-da.de/~r.hahn
<IfModule mod_userdir.c>
UserDir "C:/Benutzerverzeichnisse/"
</IfModule>
Benutzer-Verzeichnisse werden i.a. von den Benutzern selbst
gepflegt
eventuell mit eigenen Berechtigungs-Dateien (.htaccess)
Zugriffsrechte gut überlegen und steuern mit AllowOverride
258
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
259
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1.1 Webserver: Installation und Konfiguration
3.1.1 Webserver: Installation und Konfiguration
MIME-Types
Zusätzliche Features mittels Options
HTTP-Header kennzeichnet das beigefügte Dokument mit dessen
MIME-Type
CGI-Skripte außerhalb des ScriptAlias erlaubt
ExecCGI
Multipurpose Internet Mail Extension
Verknüpfungen zu anderen Verzeichnissen folgen
Server ermittelt MIME-Type aus Datei-Endung
FollowSymLinks
Zuordnung gängiger Typen in /conf/mime.types
TypesConfig conf/mime.types
zusätzliche Definitionen in /conf/httpd.conf
AddType application/vnd.ms-excel .csv
Standardvorgabe, falls kein MIME-Type ermittelt werden kann
DefaultType text/plain oder
DefaultType application/octet-stream
SymLinksIfOwnerMatch
HTML-Vorverarbeitung mittels Server-Side Includes (SSI)
Includes
IncludesNOEXEC
Inhaltsverzeichnis zeigen, wenn Indexdatei (z.B. index.html) fehlt
Indexes
Browser und Server verständigen sich über MIME-Type, Sprache
und Codierung (content negotiation); "unscharfe" Dateiendung
Browser entscheidet, wie das Dokument dargestellt wird
MultiViews
Standardeinstellung: alles außer MultiViews
was nicht angezeigt werden kann, wird zum Download angeboten
Netscape verwendet den übermittelten MIME-Type,
Internet Explorer verwendet die Datei-Endung
All
Options x y z setzt neu für
dieses Verzeichnis;
Options +x -y akkumuliert mit
vererbten Options
260
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
261
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1.2 Webserver: Zugriffsschutz und Sicherheit
Zugriffsschutz in httpd.conf
Hochschule Darmstadt
Fachbereich Informatik
Standardeinstellung sehr restriktiv
<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>
3.1.2 Webserver: Zugriffsschutz und Sicherheit
Unix root
keine sonstigen Options
.htaccess wirkungslos
Wurzelverzeichnis der Dokumente gezielt öffnen
<Directory "C:/Programme/Apache/htdocs">
AllowOverride All
.htaccess wirksam
Allow from all
Wurzel freigeben
</Directory>
Verzeichnisbezogener
Schutz wird an
Unterverzeichnisse
vererbt
Dateiname für verzeichnisspezifischen Schutz
alles andere
muss dann
explizit
freigegeben
werden
AccessFileName .htaccess
definieren
<Files ~ "^\.ht"> beginnt mit .ht
Deny from all
und schützen
</Files>
262
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
263
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1.2 Webserver: Zugriffsschutz und Sicherheit
3.1.2 Webserver: Zugriffsschutz und Sicherheit
Zugriffsschutz mit .htaccess-Dateien
Zugriffsberechtigungen als Mengen
sowohl in Deny als auch
in Allow enthalten
weder in Deny noch
in Allow enthalten
Wunsch: Der Benutzer kann die Zugriffsberechtigung selbst
pflegen, ohne einen Restart des Webservers zu benötigen
Lösung: Webserver liest im Benutzerverzeichnis eine Datei mit
Zugriffsberechtigungen: .htaccess
Beispiel:
Allow from all
Deny from 141.100
Der Name der Dateien muss in httpd.conf festgelegt werden:
Allow
AccessFileName .htaccess
Die Verwendung von lokalen Berechtigungsdateien muss in
httpd.conf freigegeben sein mit
? Deny
AllowOverride All
.htaccess bezieht sich auf das Verzeichnis, in dem es steht
Die Berechtigung wird durch 2 "Mengen" beschrieben:
deny und allow
die Auswertungsreihenfolge macht einen Unterschied:
Order allow,deny oder Order deny,allow
?
Absicht unklar
"Zweifelsfall"
hier ist die
Absicht klar
Lösung:
Regelung über
die Reihenfolge:
"order"
264
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
265
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1.2 Webserver: Zugriffsschutz und Sicherheit
3.1.2 Webserver: Zugriffsschutz und Sicherheit
Zugriffsschutz mit .htaccess-Dateien - Order
Zugriffsschutz mit .htaccess-Dateien - Beispiele
Order Deny,Allow
a) "alle" - offen für die ganze Welt
Order Allow,Deny
Allow from all
Die Deny Anweisung wird zuerst ausgewertet.
Zugang wird als Default erlaubt.
Jeglicher Zugriff der nicht in Deny enthalten ist,
darf zugreifen.
Allow
Deny
b) "niemand" – im Web nicht
verfügbar
Order Deny,Allow
Deny from all ohne Leerzeichen
Order Allow,Deny
Die Allow Anweisung wird zuerst ausgewertet.
Zugang wird als Default abgelehnt.
Jeglicher Zugriff der nicht in Allow enthalten ist,
wird abgelehnt.
Allow
und
case sensitive !
c) "alle außer…"
Order Allow,Deny
Allow from all
Deny from 141.100
Deny
Regel: Order XXX,YYY bedeutet:
Wenn Zuordnung eindeutig ist XXX, im Zweifelsfall YYY
Lokale Zugriffe verwenden
localhost und nicht die IP-Adresse!
d) "niemand, außer…"
bestimmten IP-Adressen
Order Deny,Allow
Deny from all
Allow from 141.100
Allow from localhost
e) "niemand, außer mit Passwort"
AuthType basic
AuthName "Anzeigetext"
AuthUserFile
c:\hidden\pw.sec
Require valid-user
an sicherem Ort ablegen!
erzeugen mit
htpasswd.exe –c pw.sec user
266
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
267
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1.2 Webserver: Zugriffsschutz und Sicherheit
3.1.2 Webserver: Zugriffsschutz und Sicherheit
Zugriffsschutz mit .htaccess-Dateien - Beispiele
Sicherheit von Apache-Passwörtern
a) Was ist der Unterschied?
Basic Authentification wird quasi im Klartext (base64-kodiert)
übertragen und die HTML-Antwort ebenfalls
1) Order Allow,Deny
Allow from all
2) Order Deny,Allow
Allow from all
Kein Unterschied, jeder darf
b) Was ist der Unterschied?
1) Order Deny,Allow
Allow from all
Deny from 141.100
2) Order Allow,Deny
Allow from all
Deny from 141.100
141.100 darf (!) bzw. darf nicht
c) Was ist der Unterschied?
1) Order Deny,Allow
Deny from all
Allow from 141.100
2) Order Allow,Deny
Deny from all
Allow from 141.100
etwas besser: MD5 Digest
Passwort wird im Browser gespeichert und bei jeder
Seitenanforderung an denselben Server übermittelt
notwendig, weil HTTP zustandslos ist
"niemand, außer…" bestimmten IPAdressen bzw. keiner darf
Username/Passwort ist im Server nur durch schwache
Verschlüsselung geschützt
nicht dasselbe Passwort für Website und Bankkonto verwenden !
Webserver erkennt keine Einbruchsversuche durch Ausprobieren
(mehrfach falsches Passwort eingegeben)
Order Allow,Deny ist allgemein zu
bevorzugen, weil es bei
Konfigurationsfehlern sperrt!
Betriebssysteme erkennen dies üblicherweise
allenfalls in Log-Datei erkennbar
oder auch mit http://www.htaccesseditor.com erstellen
268
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
269
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1.2 Webserver: Zugriffsschutz und Sicherheit
3.1 Webserver Software
Zugriffsrechte des Servers selbst
Beliebte Fehler im Umgang mit Apache unter Windows
Sicherheitsmaßnahme, falls Zugriffsrechte nicht sauber und
vollständig definiert sein sollten
Apache wurde unter Unix entwickelt und nach Windows portiert
Die Konfiguration über httpd.conf erfordert genaue Einhaltung einer (oft
inkonsistenten) Syntax
soll den Server selbst schützen, weniger die Dokumente
-
Apache wird normalerweise vom User "system" (root) gestartet
Apache startet Child-Prozesse, die die Requests beantworten
Child-Prozesse können eingeschränkte Zugriffsrechte haben
bei Fehlern in der Konfiguration lässt sich Apache nicht mehr starten!
Pfade brauchen teilweise am Ende einen "/"
Manchmal wird "/" verwendet, manchmal "\"
Selbst Leerzeichen in Order Deny,Allow sind ein Fehler
unbedingt die Beispiele in den Kommentaren als Vorlage beachten !
User und Group z.B. so konfigurieren, dass
- nur die freigegebenen Verzeichnisse lesbar sind
- nur das Nötigste via CGI schreibbar ist
Windows ignoriert Groß-Kleinschreibung in Dateinamen
Skripte und Links werden unter Windows auch gefunden, wenn die
Groß-Kleinschreibung falsch ist
beim Verschieben eines Projekt auf einen Web Server unter Unix
werden diese Dateien nicht mehr gefunden
Problem unter Unix: verschiedene User gegeneinander abschotten
270
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
271
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.1 Webserver Software
Zusammenfassung
Hochschule Darmstadt
Fachbereich Informatik
Grundlagen
Was ist ein Webserver?
Webserver am Markt
3.2 CGI
Grundeinstellungen
IP-Adresse & Ports, Log-Dateien
Verzeichnisse für Dokumente, Skripte, User
Besondere Dateinamen (index.html, .htaccess,...)
Pfade zu Skripten und ausführbaren Programmen (z.B. Perl)
MIME-Typen und Dateiendungen
Apache
Grundeinstellungen
Zugriffsberechtigungen und Zugriffsschutz
272
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
273
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
CGI - Common Gateway Interface
CGI - Common Gateway Interface
Webserver
Webbrowser
HTML Seite
(Eingabe- 1. Eingabedaten
übermitteln
Formular)
Daten
Schnittstelle zu Programmen, die per
HTTP-GET oder -POST aufgerufen werden können
CGI-Programm
2. CGI-Programm
starten
über Hyperlinks oder durch Absenden von Formularen
können Daten auf dem Server speichern
können (datenabhängige) HTML-Datei als Antwort generieren
wird vom Webserver angeboten / unterstützt
Programmiersprache ist nicht vorgeschrieben
HTML Seite
(Ausgabe)
4. Ergebnis
übermitteln
HTML Seite
Unix Shell, Perl, PHP, C++, Visual Basic, ...
Interpretersprachen wie Perl und PHP ersparen Compilation auf
Webserver (oft Unix-Maschinen), so dass einfacher Upload genügt
3. erzeugte
HTML-Seite
Anwendungsbeispiele:
Zugriffszähler, Gästebücher, Statistiken
Auswahl und Sortierung von Daten, Auskunftssysteme
Buchungssysteme, Online Shops
274
275
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
Ablauf einer typischen CGI-Kommunikation
Umgebungsvariablen (1)
Benutzer füllt HTML-Formular aus und klickt "Submit"
Werte werden bei einem CGI-Aufruf vom Webserver gesetzt
Informationen zum Request
REQUEST_URI=/cgi-bin/CgiTest.exe?Name=&Kommentar=
SCRIPT_NAME=/cgi-bin/CgiTest.exe
HTTP_REFERER=http://localhost/CgiTestFormular.htm
HTTP_COOKIE=Keksname=Kruemel; nochEinKeks=hart
und je nach Methode
sofern gesetzt
REQUEST_METHOD=GET
QUERY_STRING=Name=Hugo&Kommentar=BlaBla
oder
Auf das Ende achten!
REQUEST_METHOD=POST
CONTENT_LENGTH=28
CONTENT_TYPE=application/x-www-form-urlencoded
QUERY_STRING=
(ist leer)
Formulardaten hier aus der Standardeingabe (cin in C++)
Browser schickt Formulardaten mit HTTP-POST an ein CGI-Skript
(Attribut "action" des Formulars)
Server startet CGI-Skript als selbständiges Programm
Test mit .../cgi-bin/printenv.pl
(In Standard-Installation enthalten)
CGI-Skript liest Formulardaten von cin
CGI-Skript liest/speichert Daten aus/in Datenbank oder Datei
CGI-Skript schreibt HTML-Antwort nach cout
CGI-Skript schreibt Fehlermeldungen nach cerr
(werden vom Server in \logs\error.log geschrieben)
Server überträgt cout-Strom wie HTML-Datei an Browser
276
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
277
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
Umgebungsvariablen (2)
Umgebungsvariablen (3)
Informationen über den Client (Browser)
HTTP_ACCEPT=image/gif, image/jpeg, */*
Informationen über den Server
DOCUMENT_ROOT=/apache/htdocs
SCRIPT_FILENAME=/apache/cgi-bin/cgitest.exe
SERVER_ADDR=192.168.0.1
SERVER_ADMIN=admin@xyz.de
SERVER_NAME=localhost
SERVER_PORT=80
SERVER_SIGNATURE=Apache/1.3.14 Server at localhost
Port 80
SERVER_SOFTWARE=Apache/1.3.14 (Win32)
GATEWAY_INTERFACE=CGI/1.1
SERVER_PROTOCOL=HTTP/1.1
Informationen über das Server-Betriebssystem
COMSPEC=C:\WINDOWS\COMMAND.COM
PATH=C:\WINDOWS;C:\WINDOWS\COMMAND
WINDIR=C:\WINDOWS
Liste der MIME-Typen, die der Browser darstellen kann
HTTP_ACCEPT_ENCODING=gzip, deflate
HTTP_ACCEPT_LANGUAGE=de
HTTP_CONNECTION=Keep-Alive
HTTP_USER_AGENT=Mozilla/4.0 (compatible; MSIE 5.5)
HTTP_HOST=192.168.0.1
REMOTE_ADDR=192.168.0.11
REMOTE_PORT=1029
278
279
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
Codierung von Formulardaten (I)
Codierung von Formulardaten (II)
Umgebungsvariablen sind grundsätzlich Strings
Name und Wert eines Formularelements werden durch
Gleichheitszeichen = getrennt
Leerzeichen innerhalb des Werts werden durch Pluszeichen + ersetzt
die Name/Wert-Paare mehrerer Formularelemente werden durch &
getrennt.
Sonderzeichen, Umlaute etc. werden durch das Prozentzeichen %
und 2 Hexadezimal-Ziffern dargestellt
die hier aufgeführten Sonderzeichen = + & % werden in Namen und
Werten ebenfalls hexadezimal codiert
Zeichen Code
QUERY_STRING=Text=Hallo+dies+ist+ein+Test&Zeichen=%21
Zeichen Code
Zeichen Code
Zeichen Code
Leerz.
+
!
%21
"
%22
#
%23
$
%24
%
%25
&
%26
'
%27
(
%28
)
%29
+
%2B
,
%2C
/
%2F
:
%3A
;
%3B
<
%3C
=
%3D
>
%3E
?
%3F
[
%5B
\
%5C
]
%5D
^
%5E
"
%60
{
%7B
|
%7C
}
%7D
~
%7E
°
%A7
Ä
%C4
Ö
%D6
Ü
%DC
ß
%DF
ä
%E4
ö
%F6
ü
%FC
Text=Hallo+dies+ist+ein+Test&Zeichen=%21
280
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
281
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
Prinzipieller Aufbau eines CGI-Skripts
Beispiel: CGI-Skript in C++ (CgiTest.cpp)
Text=Hallo+dies+ist+ein+Test&Zeichen=%21
1. Requestmethode bestimmen
REQUEST_METHOD=GET bzw. POST
2. Für POST:
Daten von STDIN einlesen
CONTENT_LENGTH auslesen und beachten!
Es gibt kein
Daten-EndeZeichen
int main(int argc, char* argv[], char* envp[])
// envp ist ein Array von Zeigern auf nullterminierte Strings. Diese
// Strings enthalten die "Umgebungsvariablen" im Format "Name=Wert".
{
// HTTP-Header für Antwort an Browser (verlangt 2 Zeilenendezeichen):
cout << "Content-type: text/html" << endl << endl;
1. & - Zeichen trennt "Name=Wert"-Paare
// Anfang der HTML-Datei schreiben:
cout << "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\">" << endl;
cout << "<html>" << endl;
cout << "<head>" << endl;
cout << " <title>CGI-Test</title>" << endl;
cout << "</head>" << endl;
cout << "<body>" << endl;
2. = - Zeichen trennt Name und Werte
try {
Für GET:
Daten aus Umg.variable QUERY_STRING
3. Strings zerlegen und „interessante“ Daten rausfiltern
// alle Umgebungsvariablen ausgeben:
cout << " <h3>Umgebungsvariable</h3>" << endl;
cout << " <p>" << endl;
int i = 0;
while (envp[i]!=NULL) {
cout << "
" << envp[i] << "<br />" << endl;
i++;
}
cout << " </p>" << endl;
3. Sonderzeichen rekonstruieren + als Leerzeichen, %xx
4. Eigentliche Aufgabe ausführen (z.B. Datenbankanfrage)
5. Zurückliefern des Ergebnisses
-
als Datenstrom im HTML-Format
HTML-Sonderzeichen müssen codiert werden (z.B. € als &euro;)
-
Als Bilddaten im GIF oder JPEG-Format
…
282
283
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
Beispiel: CGI-Skript in Perl (echo.pl)
Apache für CGI konfigurieren
Skript-Verzeichnisse definieren
alle Dateien darin werden ausgeführt, nicht übertragen
ScriptAlias /cgi-bin/ "/apache/cgi-bin/"
ScriptAlias /php/ "/apache/php/"
oder Datei-Endungen als ausführbar definieren
Syntax
gewöhnungsbedürftig…
wenn Skripte in beliebigen Verzeichnissen liegen
AddHandler cgi-script .cgi
AddHandler cgi-script .pl
und dem MIME-Type eines Skripts den Pfad zum ausführbaren
Programm zuordnen
…aber sehr
mächtig
d.h. "Dateien dieses Typs öffnen mit ..."
Action application/x-httpd-php /php/php-cgi.exe
284
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
285
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.2 CGI
3.2 CGI
Typische CGI-Aufrufe
Untypische CGI-Aufrufe
Ein CGI-Script kann aus einer HTML-Datei heraus auf verschiedene
Arten aufgerufen werden:
direkte Eingabe der URL im Browser:
Beispiel:
Formular:
Beispiel:
Anwendung:
<form action="/cgi-bin/myscript.pl" method="get">
Anwendung: Suchdienste, Gästebücher oder elektronische Einkaufskörbe
Verweise:
Beispiel:
<a href="/cgi-bin/myscript.pl">Los</a>
Anwendung: Statistik-Abfragen
Grafikreferenz:
Beispiel:
<img src="/cgi-bin/counter.pl">
Anwendung: grafische Zugriffszähler
Test
sofortiger automatischer Aufruf beim Laden einer Seite:
CGI-Scripts, die keinen
Input vom Anwender
benötigen
Beispiel:
<img src="/cgi-bin/script.pl">
Anwendung:
Das CGI-Script muss
Daten im GIF- oder
JPEG-Format
zurücksenden.
Anzeigen einer Statistik
verzögerter automatischer Aufruf beim Laden einer Seite:
Beispiel:
Server Side Include:
Beispiel:
http://localhost/cgi-bin/printenv.pl
<meta http-equiv="refresh"
content="3; URL=/cgi-bin/script.pl">
<!--#exec cgi="/cgi-bin/counter.pl" -->
Anwendung: nach 3 Sekunden die neue URL aufrufen
Anwendung: textbasierte Zugriffszähler
286
287
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3 PHP
Situation
Hochschule Darmstadt
Fachbereich Informatik
3.3 PHP
HTML unterstützt statische Seiten
CSS unterstützt Layout
ECMA-Script bietet zusammen mit DOM mächtige Funktionalität
Bisherige CGI-Skripte liefern ein universelles Werkzeug
Anbindung an „normale“ Programmiersprachen: Perl, C++,…
Datenverarbeitung auf dem Server ist möglich
Aber:
Programmierung ist teilweise unbequem
CGI-Dateien sind vollkommen unabhängig von HTML (nicht integriert)
Universelle Programmiersprachen wurden nicht für dynamisches HTML
entwickelt
Dynamisch erzeugte Webseiten sind so schwer zu erstellen!
288
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
289
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3 PHP
3.3 PHP
Grundidee
Historie
Skriptsprache, welche speziell für die
Webprogrammierung geeignet ist, und in
HTML eingebettet werden kann.
PHP bedeutet "PHP: Hypertext Preprocessor" (rekursiv)
Integriere den PHP-Code in die HTML-Datei (ähnlich ECMA-Skipt)
Beim Aufruf durch einen Web-Browser, erkennt der Web Server,
(der die Datei zum Browser übermittelt), dass es sich um eine
HTML-Datei mit eingebettetem PHP-Code handelt.
Der server-seitig installierte PHP-Interpreter analysiert die PHP-CodePassagen, führt den Code aus und erzeugt daraus den endgültigen
Mittlerweile
HTML-Code, der an den Browser gesendet wird.
ist so viel
PHP erweitert Perl um viele aktuelle Belange des Web-Publishings
z.B. PDF-Dateien dynamisch generieren und
an den Browser senden
eingebaut,
dass
Performance
ein Thema
ist!
1994: Rasmus Lerdorf (*1968 in Grönland) beginnt mit einem Hack
1995: PHP/FI 1.0 PHP - "Personal Home Page Tools", FI - "Form Interface"
1995: PHP/FI 2.0
noch ohne echten Parser
1997: PHP 3.0 "Personal Home Page" oder "PHP HyperText Preprocessor"
echter Parser
Interpreter
grundlegende OO Notation
2000: PHP 4.0
Interpiler wie Perl 5
Performancegewinn von Faktor 2-5x im Einzelfall 100x.
neuer, schnellerer Sprachkern "Zend"
viele, neue Funktionen (mehrere Tausend)
Open Source
2003: PHP 5.0
diverse Optimierungen
Objektorientierung
2009: PHP 5.2.8 in der XAMPP-Suite enthalten (kein PHP 4 mehr!)
290
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
291
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
Primitives Beispiel
Hochschule Darmstadt
Fachbereich Informatik
<?php
header ("Content-type: text/html");
echo '<?xml version="1.0" encoding="ISO-8859-1"?>'."\n";
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="de">
<head>
<meta http-equiv="..." content="..." />
<title>Hello World</title>
</head>
<body>
Wenn in php.ini
<p> Hello
short_open_tag = On
<?php
konfiguriert ist, wird <? als
echo "World</p>";
<?php interpretiert.
?>
Ohne echo würde <?xml
</body>
falsch interpretiert!
</html>
3.3.1 PHP Grundlagen
292
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
293
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
3.3.1 PHP Grundlagen
PHP und HTML mischen
PHP Crashkurs
eine PHP-Datei ist ein Programm für den PHP-Interpreter
besondere Stärke in der Kombination mit HTML
Syntax, Operatoren und Steueranweisungen ähnlich C++
nicht typisiert ähnlich JavaScript
und nicht etwa eine HTML-Seite für den Browser
die Ausgabe des Interpreters ist typischerweise eine HTML-Seite
Text außerhalb der Klammern <?php ... ?>
wird direkt in die Ausgabe kopiert
Funktionsdeklaration mit function
keine Variablendeklaration
float, nicht double
"reiner HTML-Code" innerhalb einer PHP-Datei ist eine sehr kompakte
Ausgabeanweisung (entspricht echo)
auch Leerstellen und Leerzeilen werden in die Ausgabe kopiert
weitere Schreibweisen für die Klammer
<? ... ?>
<?= $Variable ?>
<% ... %>
<script language="php"> ... </script>
alle Variablennamen beginnen mit $
Konstantendefinition für einfache Datentypen (ohne $)
define ("GREETING", "Hello you.");
2 Modi: "PHP ausführen" und "HTML kopieren"
äußerst reichhaltige (Funktions-) Bibliotheken
zu Beginn der Datei ist der Interpreter im Modus "HTML kopieren"
Datenbankzugriffe, Mathematik, Strings, Mail, HTML,…
deshalb <?xml besser nur in echo
294
295
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
3.3.1 PHP Grundlagen
können beliebig lang sein
Strings
Ausgabe
flexible Schreibweise
bei Start von Kommandozeile:
bei Start vom Webserver:
in "..." dürfen auch einfache Variable vorkommen
echo ("<td>Anzahl: $Anzahl</td>");
Sonderzeichen wie in C++: \n \t \" \\ \$
'...' ist ebenfalls möglich als Stringklammer,
allerdings werden darin keine Variablen und Sonderzeichen ausgewertet
damit sind "geschachtelte Strings" möglich,
z.B. HTML-Attribute in PHP-Strings
echo ('<p class="Kopf">');
Verkettung von Strings mit dem Operator .
$Begruessung = "Hallo ".$Name;
Ausgabe auf Konsole
Antwort an Browser
echo ( string arg1 [, string argn...] );
print ( string arg );
int printf ( string format [, mixed args] );
echo und print sind gleichwertig
Der Zugriff über
$MeinString{$Pos};
ist deprecated!
HTML-Modus außerhalb von <?php ... ?> entspricht echo
Ausgabepuffer leeren
Zugriff auf einzelne Character (beginnt bei 0)
void flush ();
ob der Server das weiterleitet, ist nicht sichergestellt
normalerweise überflüssig
$Zeichen = $MeinString[$Zeichenposition];
\0 ist (im Gegensatz zu C++) keine Endemarke, ausgenommen jedoch
Funktionen, die als "nicht binary safe" markiert sind
296
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
297
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
Assoziative Arrays
Aufgabe
dynamisch (variable Länge), keine Deklaration erforderlich
wahlweise assoziativ oder indiziert (ähnlich JavaScript)
Zugriff auf Elemente über Schlüssel (String) oder
Index (Integer 0..count-1)
Erstellen Sie ein assoziatives Array mit den Wochentagen als
Schlüssel und der Uhrzeit Ihrer ersten Veranstaltung als Wert.
Durchlaufen Sie dieses Array mit einer foreach-Schleife und lassen
Sie sich Schlüssel und Wert zeilenweise ausgeben.
Verfeinern Sie Ihr Programm so, dass eine valide barrierefreie Seite
wie abgebildet ausgegeben wird:
$arr[] = 5;
// hängt ans Ende an
$arr[3] = "xyz";
// Zugriff per Index
$map["abc"] = 0.05;
// Zugriff per Schlüssel
$ff = array('Erdbeere' => 'rot','Banane' => 'gelb');
// Zuweisung als Tupel (Item, Value); $ff['Erdbeere']='rot'
Abarbeitung indiziert:
for ($i=0; $i<count($arr); $i++)
echo ($arr[i]);
Abarbeitung als Kollektion:
foreach($_ENV as $Schluessel => $Wert)
echo (" $Schluessel = $Wert \n");
298
299
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
3.3.1 PHP Grundlagen
Beispiel: Umgebungsvariablen mit PHP
Globale assoziative Arrays
<?php echo
Wirklich ohne _ !
'<?xml version="1.0" encoding="ISO-8859-1"' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="de">
<head>
<meta http-equiv="Content-Type" content="text/html;
charset=iso-8859-1" />
<title>Umgebungsvariablen</title>
</head>
<body>
ansonsten
interpretiert PHP
den HTML-Code
<h2>Umgebungsvariablen</h2>
<pre>
<?php
foreach($_ENV as $key => $value) {
echo "$key=$value\n";
}
?>
$GLOBALS
$_COOKIE
$_GET
$_POST
$_FILES
$_ENV
$_SERVER
$_REQUEST
"Super-Globals" erfordern
keine global-Deklaration
Liste aller globalen Variablen
Liste aller Cookies für diesen Server
alle per GET übermittelten Formulardaten
alle per POST übermittelten Formulardaten
Infos über mit POST hochgeladene Dateien
alle Umgebungsvariablen
Umgebungsvariablen vom Server
$_COOKIE und $_GET und $_POST
(d.h. potenziell gefährliche Daten vom Client)
</pre>
</body>
</html>
300
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
301
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
3.3.1 PHP Grundlagen
Zugriff auf Formulardaten
PHP stellt globale assoziative Arrays bereit
Name des Formularelements dient als Index
Beispiel: Formularauswertung
PHP hat den
QUERY_STRING
bereits dekodiert
if ( isset( $_POST["Elementname"] ))
echo $_POST["Elementname"];
☺
PHP bildet (je nach Konfiguration) Formularelemente in globale
Variable ab
sehr elegant für Schreibfaule, aber wartungsunfreundlich
if ( isset( $Elementname ))
echo $Elementname;
und gefährlich: Elementname könnte gehackt sein; ein
Hacker könnte so eine nicht-initialisierte Variable setzen
seit 4.2.0 abgeschaltet in php.ini: register_globals = Off
magic_quotes_gpc = Off (sonst wird " zu \")
isset prüft jeweils, ob die Variable überhaupt existiert
<?php
<?php
if ($_SERVER["REQUEST_METHOD"]=="GET") {
$Params = $_GET; echo ("(mit GET übermittelt)\n");
}
else if ($_SERVER["REQUEST_METHOD"]=="POST") {
$Params = $_POST; echo ("(mit POST übermittelt)\n");
}
if (isset($Params["Anwendername"]))
echo ("Anwendername=".$Params["Anwendername"]."\n");
if (isset($Params["KommentarText"]))
echo ("KommentarText=".$Params["KommentarText"]."\n");
echo ("</pre>");
?>
302
303
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
Aufgabe
Strukturierung und Wiederverwendung
Schreiben Sie ein PHP-Programm:
In einem Formular hat die Benutzerin ihren Namen in das Eingabefeld
<form action=„greeting.php“ method=„get“>
<input id=„name“ type=„text“> eingegeben und sie möchten sie mit einer
netten Begrüßung willkommen heißen. (Korrigieren Sie das Tag
zuvor, so dass es valide und hilfreich ist ;-)
typische Struktur
kleiner Nachteil:
PHP muss immer
mehrere Dateien öffnen
viele kleine Programme anstatt eines großen Programms mit vielen
Funktionen
ein Formular benötigt oft 2 PHP-Seiten (Aufbau und Auswertung)
benötigte Klassen oder Funktionen in eigene PHP-Datei einbinden
require_once "Pfadname.php";
Probleme bei der Ausgabe von
Benutzereingaben???
vergleichbar mit #include in C++
require_once und include_once vermeiden Endlos-Einbindungen
fehlende Datei bewirkt Abbruch bei require, Warnung bei include
kann in if-Anweisungen stehen und wird dann nur bedingt inkludiert
Dateiname kann Laufzeitausdruck sein, nicht nur eine Konstante
innerhalb der require-Datei wird im HTML-Modus begonnen !
Variablen sind "require-übergreifend" sichtbar
304
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
305
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.1 PHP Grundlagen
3.3.1 PHP Grundlagen
Konfiguration von PHP
Apache für PHP konfigurieren
php.ini ist zentrale Konfigurationsdatei
PHP unter Verwendung des CGI
PHP-Installationsverzeichnis zum Skript-Verzeichnis erklären:
ScriptAlias /php/
php/ "/apache/php
"/apache/php/"
apache/php/"
PHP-Interpreter (CGI-Version) für Dateien mit MIME-Type PHP aufrufen:
Action application/xapplication/x-httpdhttpd-php /php/phpphp/php-cgi.exe
MIME-Type PHP der Datei-Endung .php zuordnen:
AddType application/xapplication/x-httpdhttpd-php .php
PHP-Dateien können
in jedem Dokument auch index.php als Startseite zulassen:
Verzeichnis liegen
DirectoryIndex index.php
CGI Ausführung erlauben (nicht nötig für Standard-PHP-Verzeichnisse)
Options ExecCGI
register_globals = Off // On ist deprecated!
Form-Elemente werden nicht mehr in globale Variable abgebildet
(Zugriff nur noch über assoziative Arrays)
magic_quotes_gpc = Off // Ab PHP 6.0.0 deprecated!
(sonst wird " zu \" für $_GET, $_POST, $_COOKIE)
phpinfo();
generiert eine Übersicht
zu PHP als HTML-Seite
effizient: PHP als Apache-Module
(mit Pfad zu PHP.ini)
wird eingebunden, wenn Apache compiliert wird
In der Installation von XAMPP ist PHP5 integriert
es gibt oft mehrere PHP.ini –
Dateien im Filesystem – aber nur
eine wird verwendet!
306
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
307
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
SELFPHP
http://www.selfphp.info
PHP Entwicklung
Hochschule Darmstadt
Fachbereich Informatik
Eigene Funktionen definieren mit function
function hello($text1, $text2)
{
echo "Hello World <br></br>";
echo "$text1 $text2 <br></br>";
return true; // Rückgabewert
}
3.3.2 PHP Entwicklung
Optionale Funktions-Parameter mit Default-Wert:
function hello($text1, $text2="Test")
Call by Reference
function change(&$myReference)
Während der Entwicklung: alle Fehlercodes ausgeben mit
error_reporting(E_ALL);
Im Produktivbetrieb die
Fehlermeldungen in Log-Datei
schreiben und nicht ausliefern!
308
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
309
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Strings
Sonderzeichen in Strings
Ein String kann auf drei verschiedene Weisen geschrieben werden.
Einfache Anführungszeichen (single quote) " als "
komplexe
im erzeugten HTML bzw. den ECMA-Script Anteilen muss die
jeweilige Syntax beachtet werden
echo 'Variablen werden $nicht $ausgewertet\n';
Berechnungen
und
//Ausgabe: Variablen werden $nicht $ausgewertet\n
Doppelte Anführungszeichen (double quote)
$myvar = 'Variable';
" als &quot;
quot; oder \"
echo "${myvar}n werden ausgewertet\n";
//Ausgabe: Variablen werden ausgewertet [newline]
Abgrenzung
von Variablennamen in {}
das Stringformat erfordert die Ersetzung mancher Sonderzeichen
Stringbegrenzer ist " und muss zur Ausgabe "escaped" werden: \"
für ECMA-Script sogar "doppelt": &quot;
für die Weiterverarbeitung und Speicherung (z.B. in der Datenbank)
sollen Daten in "reiner Form" stehen
Heredoc Notation
Stringbehandlung wie mit doppelten Anführungszeichen - nur ohne
Anführungszeichen; Zeilenumbrüche werden übernommen
" als " Schluss"tag" muss in der
echo <<<EOT kein Semikolon!
ersten Spalte stehen
${myvar}n werden ausgewertet
- und ganz alleine!
EOT;
//Ausgabe: Variablen werden ausgewertet [newline]
PHP bietet diverse Funktionen zum Wandeln von Strings zwischen den
Formaten
310
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
311
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Sonderzeichen in Strings - sprachübergreifend
Übergabe mit Mehrfachauswahl – Das Problem
übermittelte Formulardaten werden Strings für
HTML zum Anzeigen (ersetzt & < > " ' )
htmlentities()
ersetzt auch die
$Wert = htmlspecialchars($Wert);
Umlaute!
SQL für Anfragen etc. (ersetzt " ' )
$Wert = $mysqli->real_escape_string($Wert);
HTML
Erzeugen von JavaScript in HTML aus PHP-echo:
echo("<p onclick=\"alert(&quot;Hallo&quot;);\">");
<p onclick="alert(&quot;Hallo&quot;);">
Browser alert("Hallo");
PHP ergibt für GET: http://localhost/..../Echo.php?myselect=2&myselect=4
Einfacher mit heredoc-Notation:
<?php
echo <<<EOT
<!– Hier steht der ganz normale HTML-Code -->
<!DOCTYPE…
$myvar = <<<LABEL ... LABEL;
</html>
liest den umschlossenen Text in die
EOT;
Variable $myvar !
?>
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
überträgt (URL): myselect=2&myselect=4
PHP liefert:
myselect=4
(als Umg.variable in $_GET)
mit POST sieht man nichts,
aber das Problem bleibt!
PHP
Es wird nur der letzte Wert als Umgebungsvariable übernommen!
312
313
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Übergabe mit Mehrfachauswahl – Die Lösung
Formulare und Sicherheit
später ausführlicher
wer weiß schon, welche Daten ein gehacktes Formular übermittelt ...
deshalb NICHT die übermittelten Parameter auswerten:
foreach ($_POST as $Name => $Wert)
$Datensatz[$Name] = $Wert;
array
sondern die erwarteten Parameter:
[]
überträgt:
PHP
myselect%5B%5D=2&myselect%5B%5D=4
print_r($_GET);
liefert jetzt:
Befehl zum
Ausgeben
von Arrays
if (isset ($_POST["ElemA"]) &&
istZahl($_POST["ElemA"])
$Datensatz["ElemA"] = $_POST["ElemA"];
Speichern ($Datensatz);
Syntax und
Wertebereich
überprüfen
Array ( [myselect] => Array ( [0] => 2 [1] => 4 ) ) myselect=Array
Zugriff auf Position $i über
$MYS = $_GET[myselect];
echo ($MYS[$i]);
314
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
315
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Überprüfung auf unerwünschte Zeichen
Objektorientierung (I)
brauchbar seit PHP 5
am einfachsten mit regulären Ausdrücken
Klassen und Objekte ähnlich Java
bool preg_match (string pattern, string subject);
Beispiele
ereg vermeiden; ist nicht binary safe
Dezimalzahl mit Vorzeichen und max. 10 Ziffern:
- $isDecimal = preg_match("/-{0,1}[0-9]{1,10}/", $p);
- Minus darf 0 oder 1-mal auftreten, dann
1 bis 10 Zeichen aus der Menge 0-9
Vererbung
übliche Bezeichner-Syntax:
class a extends b { ... } // aber keine Mehrfachvererbung
interface i { ... } bzw. class c implements i { ... }
$isAlphaNum = preg_match(
"/^[a-zA-Z][a-zA-Z0-9_]+$/", $p);
- zuerst ein Buchstabe und dann Buchstaben, Zahlen oder _
wenig genutzt in Bibliotheken
316
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Objekte werden ausschließlich mit new erzeugt und über Referenzen
angesprochen
Attribute deklarieren mit: var $Attribut;
Basisklassenkonstruktor explizit aufrufen
parent::
bezeichnet Basisklasse
$this
verweist auf Objekt
->
für Zugriff auf Attribute (ohne $) und Methoden
Bibliotheken bestehen oft aus Gruppen von Funktionen
Musterbeispiel: herstellerunabhängige Kapselung des
Datenbankzugriffs in PEAR::DB (bzw. PEAR::MDB2)
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
317
3.3.2 PHP Entwicklung
Objektorientierung (II)
Aufgabe
Neue PHP-Sprachelemente im OO-Umfeld:
Schreiben Sie eine Klasse in PHP:
public, protected, private statt var
static $x = 0; const y = 0;
$instance = new SimpleClass();
// weist Referenz zu
$Kopie = clone $instance;
neu: Type Hinting für Klassen
class a extends b { ... }
function f1 (a $param) { ... }
abstract class ..., abstract function ...
interface i { ... }
class c implements i { ... }
final function f2 { ... } // wie Java; d.h. nicht virtual
magic methods mit dem Namen __xxx werden implizit aufgerufen
__construct, __destruct, __clone
Vergleich: == gleiche Attributwerte
=== selbes Objekt
Im Konstruktor übergeben Sie ein Array von Namen.
Die Methode Show gibt die Namen als ul aus.
Schreiben Sie eine aufrufende Seite, die die zuvor implementierte
Klasse nutzt.
Mit PHP5 sind die üblichen OO-Konzepte umsetzbar !
318
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
319
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Einsatz von Klassen am Beispiel Observermuster (I)
Einsatz von Klassen am Beispiel Observermuster (II)
Observer
Subject
observers:Observer[]
+attach(observer:Observer):void
+detach(observer:Observer):void
#notify():void
+getState():mixed
Observer
subject:Subject
protected
+attach(subject:Subject):void
+detach():void
+update():void
Subject
observers:Observer[]
+attach(observer:Observer):void
+detach(observer:Observer):void
#notify():void
+getState():mixed
abstrakt
1 Subject
ConcreteSubject
Datentyp Observer
bekannt machen
*
ConcreteObserver
state:mixed
state:mixed
<<implements>>+getState():mixed
+doSomething():void
+__construct(subject:Subject):void
<<implements>>+update():void
Quelle: S. Bergmann http://www.professionelle-softwareentwicklung-mit-php5.de
320
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
Quelle: S. Bergmann http://www.professionelle-softwareentwicklung-mit-php5.de
321
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Einsatz von Klassen am Beispiel Observermuster (III)
Fehlerbehandlung – die traurige Art
Häufige Art der Fehlerbehandlung
sofortiger Abbruch
die ("ungültiger Parameter");// Meldung an Browser
oder
exit (5);
// Fehlercode an OS
Unterdrückung der Fehlermeldungen mit dem Fehlerkontrolloperator @
@$f = fopen("myfile.txt","r");
Subject
ConcreteSubject
state:mixed
<<implements>>+getState():mixed
+doSomething():void
Normalerweise endet ein PHP-Programm am Dateiende und erzeugt
dann (hoffentlich) eine sinnvolle HTML-Ausgabe
Bei Fehlern entsteht eine unvollständige HTML-Datei und es hängt vom
Browser ab, was angezeigt wird
es entstehen häufig leere Seiten oder Layout-Trümmer
Der Anwender erhält oft keine Rückmeldung wo das Problem liegt –
geschweige denn, ob er etwas dagegen tun kann
Observer und ConcreteObserver werden analog umgesetzt !
Quelle: S. Bergmann http://www.professionelle-softwareentwicklung-mit-php5.de
322
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
323
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Ausnahmebehandlung – wie es sein sollte
Ausnahmebehandlung: Beispiel
<?php
header ("Content-type: text/html");
error_reporting (E_ALL);
Seit PHP 5 gibt es echte Ausnahmebehandlung
if (...) { // was auch immer schief gehen kann
throw new Exception("Meine Fehlermeldung");
}
try { // hier kommt der problematische Aufruf
}
catch (Exception $e) {
// typisiert !
echo $e->getMessage();
// besser: komplettes HTML
}
finally { /* (optional) wird immer ausgefuehrt */ }
HTML-Schachtelungsstruktur kann ordentlich abgeschlossen werden
sinnvolle Meldungen können gezielt angezeigt werden
(z.B. Alternative Kontaktmöglichkeit oder
Info, dass der Admin benachrichtigt wurde) etc.
function dividiere ($divident, $divisor) {
if ($divisor == 0){ // Es soll durch null geteilt werden -> Exception
throw new Exception("Division durch null ist nicht definiert");
}
$erg = $divident/$divisor;
return $erg;
}
// hier kommt der HTML-Header und der Beginn des <body>
try {
// leitet den Block ein, in dem Exceptions abgefangen werden
dividiere(2,0);
// generiert eine Exception
}
catch (Exception $fehler){ // fängt die Exception ab
echo "<p>Ausnahmefehler: ".$fehler->getMessage()."</p>";
}
finally
{ /* (optional) wird immer ausgefuehrt */ }
// hier kommen das Ende des <body> und die üblichen schließenden Tags
324
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
// MIME-Type der Antwort definieren; vor HTML !
// alle möglichen Fehlermeldungen aktivieren
Abgewandelt von: C. Möhrke "Besser PHP programmieren"
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
325
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Ausnahmebehandlung für verschiedene Fälle
PHP5 vs. PHP4
Häufig sollen Fehlern durch die Anwendung unterschieden werden
PHP5 ist mit Blick auf Abwärtskompatibilität zu PHP4 entwickelt –
aber es gibt dennoch einige wichtige Unterschiede:
das Öffnen einer nicht vorhandenen Datei erzeugt immer einen Fehler
dieser Fehler ist manchmal kritisch (Datenbank nicht vorhanden) und
manchmal eher nicht (css-Datei fehlt)
Durch Ableiten von der Klasse Exception können verschiedene
Fehlertypen definiert und unterschiedlich abgefangen werden
Der Konstruktor muss definiert werden!
PHP4 übergibt stets eine Kopie von Objekten; PHP 5 übergibt
Referenzen. Kopien müssen bei Bedarf explizit erzeugt werden
($Kopie = clone $instance;)
In PHP4 hieß der Konstruktor genauso wie die Klasse
(und wurde bei Namensänderungen oft vergessen).
Der Konstruktor hat ab PHP5 einen klassenunabhängigen Namen
(__construct) und muss innerhalb der Klasse definiert werden.
Objekte können in PHP5 erst erzeugt werden, nachdem die Klasse
deklariert ist
Es wurden die bereits genannten neuen Schlüsselwörter eingeführt
(z.B. abstract, clone, final usw.)
class criticalError extends Exception {
public function __construct ($Message) {
parent::__construct($Message);
}
}
class noncriticalError extends Exception {...}
...
try{...}
catch (criticalError $fehler){...}
catch (noncriticalError $fehler){...}
Abgewandelt von: C. Möhrke "Besser PHP programmieren"
326
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
327
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
PHP bietet sehr viele Funktionen
Anwendung von PHP: PDF-Erzeugung
Array-Funktionen
Crack-Funktionen
Dateisystem-Funktionen
Datums- und Zeit-Funktionen
Functions-Funktionen
Image-Funktionen
Klassen und Objekt-Funktionen
Kontroll-Mechanismen
Mail-Funktionen
Mathematische-Funktionen
MySQL-Funktionen
PDF-Funktionen
PHP-Deklaration
PHP-Informationen
Reguläre Ausdrücke
Session-Funktionen
String-Funktionen
URL-Funktionen
Variablen-Funktionen
Verzeichnis-Funktionen
Sonstige-Funktionen
Es gibt mehrere Bibliotheken zum Erzeugen von PDFs
pdflib (http://www.pdflib.com)
- ist bereits bei XAMPP dabei und kann als PHP-Modul aktiviert werden
- für kommerzielle Anwendungen fallen Lizenzkosten an
fpdflib (http://fpdf.org/)
- eine PHP-Klasse, die Funktionen zum Erstellen von PDFs bietet
- funktioniert ohne nennenswerte Installation
- kostenlos und auch kommerziell frei einsetzbar
PDF-Bibliotheken definieren <?php /* fpdf Tutorial 1*/
require('fpdf.php');
ein spezielles DOM
die Einarbeitung ist die
größte Arbeit
http://www.selfphp.de oder http://www.php.net/
bieten eine Übersicht der PHP-Funktionen
$pdf=new FPDF();
$pdf->AddPage();
$pdf->SetFont('Arial','B',16);
$pdf->Cell(40,10,'Hello World!');
$pdf->Output();
?>
328
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
329
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
3.3.2 PHP Entwicklung
3.3.2 PHP Entwicklung
Plattformunabhängigkeit ?
Zusammenfassung
ja: derselbe Interpreter für viele Betriebssysteme
Grundlagen
Idee
Historie
aber: jede Installation ist anders
Notation
sehr viele Features abhängig von
besser wäre: in der Anwendung
Konfigurationsparametern in PHP.INI
und / oder auch von Compiler-Schaltern beim Build
Abfragefunktionen in der Gruppe "PHP options & information"
kein Problem, wenn der Interpreter nur eine Anwendung bedient
dann kann man ihn passend konfigurieren
(muss natürlich bei PHP-Update bewahrt werden)
aber sehr nachteilig bei mehreren Anwendungen
interessanter Weg zur Behinderung von Portabilität !
☺
Grundstil C++
Integration in HTML <?php ...
?>
Variablennamen beginnen mit $
Strings., "...", '...', echo <<<EOT
Arrays und deren Übergabe
Umwandlung von Sonderzeichen
Objektorientierung
Ausnahmebehandlung
Jetzt können wir mächtige Skripts schreiben und laufen lassen
– aber was tun wir damit?
330
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10
331
Hahn, Kreling, Blechschmidt-Trapp, h_da Fachbereich Informatik, Entwicklung webbasierter Anwendungen, WS 09/10