E-Book, Deutsch, 558 Seiten
Reihe: Rheinwerk Computing
Theis Einstieg in PHP 8 und MySQL
15. Auflage 2023
ISBN: 978-3-8362-9276-4
Verlag: Rheinwerk
Format: EPUB
Kopierschutz: 0 - No protection
Ideal für Programmiereinsteiger
E-Book, Deutsch, 558 Seiten
Reihe: Rheinwerk Computing
ISBN: 978-3-8362-9276-4
Verlag: Rheinwerk
Format: EPUB
Kopierschutz: 0 - No protection
Mit diesem Buch lernen Sie schnell und praxisnah, wie Sie dynamische Webseiten mit PHP und MySQL (oder mit MariaDB) entwickeln. Schritt für Schritt zeigt Ihnen unser Autor Thomas Theis anhand leicht nachvollziehbarer und sofort einsetzbarer Beispiele, wie Sie mit PHP programmieren und auf Datenbanken zugreifen. Es werden alle Themen behandelt, die Sie zum Erstellen von Blogs, Webshops, Chats, Foren u. Ä. benötigen. Ein Programmierkurs am Anfang des Buches stellt sicher, dass auch Programmieranfänger problemlos einsteigen können.
Aus dem Inhalt:
- Grundlagen
- PHP-Programmierkurs
- Daten senden und auswerten
- Datenbanken anlegen
- Objektorientiert programmieren
- Fortgeschrittene Techniken
- Prepared Statements
- Constructor Property Promotion
- Callbacks
- Multibyte-Funktionen
- XML und Ajax
- Sicherheit erhöhen
- Verschlüsselungen
- Hilfen
- Installation des lokalen Webservers
- Hinweise für Windows-, Mac- und Ubuntu-Nutzer
Die Fachpresse zur Vorauflage:
PHPmagazin: »Wenn Sie einem JavaScript-Jockey schnell Grundkenntnisse von PHP verpassen müssen, führt an der 14. Auflage kein Weg vorbei.«
Thomas Theis ist Dipl.-Ing. für Technische Informatik und arbeitet als Berater und Trainer. Seit vielen Jahren gibt er als EDV-Dozent Kurse in verschiedenen Programmiersprachen. Er ist Autor vieler erfolgreicher Fachbücher.
Autoren/Hrsg.
Weitere Infos & Material
Materialien zum Buch ... 18
Einführung ... 19
1. PHP-Programmierkurs ... 23
1.1 ... Einbettung von PHP ... 23
1.2 ... Variablen, Datentypen und Operatoren ... 27
1.3 ... Einfache Formularauswertungen ... 38
1.4 ... Verzweigungen ... 47
1.5 ... Mehr über Verzweigungen ... 62
1.6 ... Schleifen ... 72
1.7 ... Funktionen ... 83
1.8 ... Behandlung von Fehlern ... 98
1.9 ... Felder ... 103
1.10 ... Mehr über Funktionen ... 109
1.11 ... Beispiele ... 131
2. Daten senden und auswerten ... 139
2.1 ... Textelemente ... 139
2.2 ... Auswahlelemente ... 147
2.3 ... Aktionselemente ... 155
2.4 ... Weitere Möglichkeiten ... 159
2.5 ... Beispiele ... 172
2.6 ... PHP-Programme publizieren ... 176
3. Datenbanken mit MySQL ... 177
3.1 ... Einführung ... 177
3.2 ... Verwaltung mit phpMyAdmin ... 179
3.3 ... Datensätze anzeigen ... 185
3.4 ... Datensätze auswählen ... 190
3.5 ... Ausgabe in Tabellenform ... 194
3.6 ... Auswahl über Formulare ... 196
3.7 ... Prepared Statements ... 200
3.8 ... Datensätze erzeugen ... 208
3.9 ... Datensätze ändern ... 215
3.10 ... Datensätze löschen ... 223
3.11 ... SQL-Funktionen für Zeichenketten ... 225
3.12 ... Aggregatfunktionen ... 227
3.13 ... Gruppierung ... 230
3.14 ... Benutzeroberfläche mit JavaScript und CSS ... 231
3.15 ... Beispiel Eventplanung ... 232
3.16 ... Eine Datenbank mit mehreren Tabellen ... 232
3.17 ... Ein Datenbankbrowser ... 237
3.18 ... Datenbanken publizieren ... 238
4. Objektorientierung in PHP ... 243
4.1 ... Was ist objektorientierte Programmierung? ... 243
4.2 ... Klassen und Objekte ... 244
4.3 ... Konstruktor und Ausgabe ... 249
4.4 ... Destruktor ... 252
4.5 ... Schreibgeschützte Eigenschaften ... 253
4.6 ... Optionale und benannte Parameter ... 255
4.7 ... Konstanten und statische Elemente ... 258
4.8 ... Kopie und Referenz ... 261
4.9 ... Typhinweise ... 264
4.10 ... Objekte und Felder ... 266
4.11 ... Vererbung ... 271
4.12 ... Schnittstellen ... 275
4.13 ... Enumerationen ... 279
4.14 ... Serialisierung ... 281
4.15 ... Beispiel »Scheck« ... 284
4.16 ... Kopfrechnen, objektorientiert ... 285
5. Fehler behandeln, Sicherheit erhöhen ... 287
5.1 ... Anzeige von Fehlern ... 287
5.2 ... Dauerhafte Konfiguration der Anzeige von Fehlern ... 287
5.3 ... Änderung der Anzeige ... 290
5.4 ... Angriffe und Sicherheit ... 291
6. Zeichenketten ... 295
6.1 ... Eigenschaften und Umwandlungen ... 295
6.2 ... Suchen und Ersetzen ... 297
6.3 ... Positionen und Teilzeichenketten ... 299
6.4 ... Zeichenketten und Felder ... 301
6.5 ... Zeichen und Codenummern ... 302
6.6 ... Verschlüsselung ... 303
7. Dateien und Verzeichnisse ... 309
7.1 ... Eine Textdatei schreiben ... 309
7.2 ... Eine Textdatei lesen ... 311
7.3 ... Ein einfacher Webcounter ... 314
7.4 ... Eine CSV-Datei schreiben ... 315
7.5 ... Eine CSV-Datei lesen ... 317
7.6 ... Informationen über Dateien ... 318
7.7 ... Informationen über ein Verzeichnis ... 319
7.8 ... Informationen über einen Verzeichnisbaum ... 322
8. Felder ... 325
8.1 ... Ein Feld entpacken ... 325
8.2 ... Ein Feld kopieren ... 326
8.3 ... Ein Feld als Parameter ... 327
8.4 ... Ein Feld als Rückgabewert ... 328
8.5 ... Zufällige Werte aus einem Feld ... 329
8.6 ... Typhinweise ... 331
8.7 ... foreach-Schleife, Kopie und Referenz ... 331
8.8 ... Operationen für numerisch indizierte Felder ... 333
8.9 ... Sortierung eines assoziativen Feldes ... 341
8.10 ... Zweidimensionale Felder ... 343
8.11 ... Callback-Funktionen ... 352
8.12 ... Benutzerdefinierte Sortierung ... 354
8.13 ... Dekonstruktion ... 357
8.14 ... Mengenlehre ... 360
9. Datum und Zeit ... 365
9.1 ... Zeit ermitteln und ausgeben ... 365
9.2 ... Zeit formatiert ausgeben ... 366
9.3 ... Zeitangabe prüfen ... 369
9.4 ... Absolute Zeitangabe erzeugen ... 370
9.5 ... Relative Zeitangabe erzeugen ... 372
9.6 ... Mit Zeitangaben rechnen ... 373
9.7 ... Zeitstempel in Datenbanken ... 377
9.8 ... SQL-Funktionen für Zeitangaben ... 379
9.9 ... Ermittlung von Feiertagen ... 382
9.10 ... Kopfrechnen mit Zeitmessung ... 383
10. Mathematische Funktionen ... 385
10.1 ... Ganze Zahlen und Fließkommazahlen ... 385
10.2 ... Exponentialoperator ** ... 387
10.3 ... PHP als Taschenrechner ... 388
10.4 ... Ganze Zahlen, Runden ... 390
10.5 ... Ganzzahlige Division und Modulo ... 392
10.6 ... Extremwerte ... 393
10.7 ... Winkelfunktionen ... 394
10.8 ... Mischen ... 395
10.9 ... Stellenwertsysteme ... 397
10.10 ... Bit-Operatoren ... 399
11. Sessions und Cookies ... 403
11.1 ... Session-Management ... 404
11.2 ... Zugriffszähler mit Sessions ... 404
11.3 ... Geschützte Website mit Sessions ... 406
11.4 ... Webshop mit Sessions ... 411
11.5 ... Cookies ... 419
11.6 ... Die Existenz von Cookies prüfen ... 419
11.7 ... Daten speichern mit Cookies ... 421
12. Datenbanken mit SQLite3 und PDO ... 425
12.1 ... SQLite3 ... 425
12.2 ... PDO ... 435
13. XML ... 439
13.1 ... Einlesen eines einzelnen Objekts ... 439
13.2 ... Sammlung von gleichartigen Objekten ... 442
13.3 ... Zugriff auf Attribute ... 444
13.4 ... Interne XML-Daten ... 446
13.5 ... Speicherung von Objekten ... 447
14. Ajax ... 449
14.1 ... Hallo Ajax ... 449
14.2 ... Parameter senden ... 452
14.3 ... XML-Dateien lesen ... 455
14.4 ... JSON-Dateien lesen ... 459
14.5 ... Zugriff auf eine MySQL-Datenbank ... 465
14.6 ... Weitere Ereignisse ... 468
15. Grafiken programmieren ... 471
15.1 ... Installation testen ... 471
15.2 ... Grafik anzeigen ... 472
15.3 ... Texte anzeigen ... 476
15.4 ... Bilder anzeigen ... 479
15.5 ... Zeichnungen erzeugen ... 485
15.6 ... Beispielanwendungen ... 492
16. PDF-Dateien erstellen ... 495
16.1 ... Installation ... 495
16.2 ... PDF-Dokument erzeugen ... 495
16.3 ... Text in Zelle ... 497
16.4 ... Fließtext, Schriftparameter ... 499
16.5 ... Tabellen ... 501
16.6 ... Kopf- und Fußzeile ... 503
16.7 ... Ein Bild aus einer Datei laden ... 506
16.8 ... Hyperlinks ... 507
16.9 ... Linie, Rechteck, Position ... 510
17. Automatisierter E-Mail-Versand ... 513
17.1 ... Eine erste E-Mail ... 513
17.2 ... Weitere Header ... 514
17.3 ... Ein E-Mail-Formular ... 515
17.4 ... E-Mails mit PHPMailer ... 517
18. Beispielanwendungen ... 519
18.1 ... Die Anwendung »Chat« ... 519
18.2 ... Die Anwendung »Blog« ... 520
18.3 ... Die Anwendung »Forum« ... 521
18.4 ... Die Anwendung »Multiplayer« ... 523
18.5 ... Die Anwendung »Steganografie« ... 527
Anhang ... 531
A ... Installationen und Hilfestellungen ... 531
Index ... 545
1.2 Variablen, Datentypen und Operatoren
Innerhalb eines Programms können Informationen zur späteren Verwendung in Variablen gespeichert werden.
1.2.1 Datentypen
Variablen unterscheiden sich in ihren Datentypen. PHP unterstützt unter anderem Datentypen für:
-
ganze Zahlen
-
Fließkommazahlen, also Zahlen mit Nachkommastellen
-
Zeichenketten (auch Strings genannt)
-
Felder (ein- und mehrdimensionale Felder von Variablen)
-
Objekte
Der Datentyp für eine PHP-Variable wird nicht beim Programmieren festgelegt, sondern richtet sich nach dem Zusammenhang, in dem die Variable verwendet wird. Sie kann bei ihrem ersten Erscheinen sofort benutzt werden und muss dem Programm nicht vorher bekannt gemacht werden. Sie kann ihren Datentyp innerhalb eines Programms wechseln.
Seit PHP 7.0 gibt es die Möglichkeit, die Datentypen der benutzten Variablen beim Aufruf von Funktionen genauer zu prüfen. Dabei wird mit sogenannten Typhinweisen gearbeitet. Typhinweise verbessern die Lesbarkeit und erleichtern den Ablauf und die Pflege von PHP-Programmen. Mehr dazu finden Sie in Abschnitt 1.10.11.
Zunächst geht es um die einfachen Datentypen (Zahlen und Zeichenketten). Später kommen Felder und Objekte hinzu.
1.2.2 Namen für Variablen
Für den Namen einer Variablen gelten folgende Regeln:
-
Er muss mit einem Dollarzeichen beginnen.
-
Er darf keine Leerzeichen enthalten.
-
Er darf nur aus Buchstaben und Ziffern bestehen, wobei das erste Zeichen ein Buchstabe sein muss. Es sind Groß- und Kleinbuchstaben erlaubt, zwischen denen jedoch unterschieden wird ($HokusPokus ist nicht das Gleiche wie $hokuspokus).
-
Er darf keine sprachspezifischen Zeichen wie zum Beispiel die deutschen Umlaute oder ß (»scharfes S«) enthalten.
-
Er darf als einziges Sonderzeichen den _ (Unterstrich) enthalten.
-
Er darf nicht mit einem reservierten Wort identisch sein, zum Beispiel mit einem Befehl aus der Sprache PHP.
Sie sollten selbsterklärende Namen vergeben. Dies hat den Vorteil, dass sich jeder sofort zurechtfindet, der sich später mit dem Programm befasst. Einige Beispiele sind: $Startmeldung, $Temperaturwert, $XKoordinate, $Ywert.
Diese Regeln gelten in ähnlicher Form für die Namen von Konstanten (siehe Abschnitt 1.2.8), Funktionen (siehe Abschnitt 1.7) sowie Klassen und Methoden (siehe Kapitel 4). Eine wichtige Ausnahme: Nur die Namen von Variablen beginnen mit einem Dollarzeichen.
1.2.3 Variablen für Zahlen
Betrachten Sie einmal das folgende Programm, in dem verschiedene Zahlen gespeichert und ausgegeben werden:
$ganzeZahl = -14;
$kommaZahl = 1.35;
$grosseZahl = 5.5e6;
$kleineZahl = 3.8e-3;
$separatorGross = 1_580_000_000;
$separatorKlein = 0.000_000_001_580;
echo $ganzeZahl . "
";
echo $kommaZahl . "
";
echo $grosseZahl . "
";
echo $kleineZahl . "
";
echo $separatorGross . "
";
echo $separatorKlein;
?>
Listing 1.3 Die Datei »zahl_variable.php«
Es wird eine Variable mit dem Namen $ganzeZahl eingeführt. Dieser Variablen wird der Wert -14 zugewiesen, wodurch $ganzeZahl zu einer Variablen für eine ganze Zahl wird. Bei negativen Werten wird ein Minuszeichen vorangestellt.
Die Variable $kommaZahl wird eingeführt. Ihr wird der Wert 1.35 zugewiesen, also wird $kommaZahl zu einer Variablen für eine Fließkommazahl. Dabei muss die englische Schreibweise mit einem Punkt als Dezimaltrennzeichen verwendet werden.
Eine Zahl kann auch als Exponentialzahl eingegeben werden. Diese Schreibweise eignet sich besonders für sehr große oder sehr kleine Zahlen:
-
Die Variable $grosseZahl erhält den Wert 5.5e6. Er wird gelesen als 5.5 × 10 hoch 6, also 5.5 × 1000000. Es ergibt sich der Wert 5500000.
-
Die Variable $kleineZahl erhält den Wert 3.8e-3. Er wird gelesen als 3.8 × 10 hoch -3, also 3.8 × 0.001. Es ergibt sich der Wert 0.0038.
Seit PHP 7.4 kann ein Unterstrich als Separator dienen. Ein Separator hilft bei der Eingabe von Zahlen mit vielen Ziffern, kann an beliebiger Stelle eingesetzt werden und hat keinen Einfluss auf den Zahlenwert. Lange Ziffernfolgen werden meist in Dreiergruppen unterteilt.
Mit echo lassen sich nicht nur Texte, sondern auch die gespeicherten Werte von Variablen ausgeben. Auch hier gilt: Mehrere Teile der Ausgabe werden mithilfe eines Punkts miteinander verbunden. Abbildung 1.4 zeigt die Ausgabe des Programms im Browser.
Abbildung 1.4 Zahlen
1.2.4 Rechenoperatoren für Zahlen
Bei Zahlen können Sie die Rechenoperatoren (arithmetischen Operatoren) aus Tabelle 1.1 verwenden.
| Operator | Bedeutung |
|---|
| + | Addition |
| - | Subtraktion |
| * | Multiplikation |
| / | Division |
| % | Modulo-Operation: der Rest bei einer ganzzahligen Division |
| ** | Potenzieren mithilfe des Exponentialoperators. Ein Beispiel: 2 ** 3, gesprochen: »2 hoch 3«. Mehr dazu folgt in Abschnitt 10.2. |
Tabelle 1.1 Rechenoperatoren in PHP
Ein Beispiel mit einigen Berechnungen:
$zahlEins = 3 * 2 + 2.5 * 4 - 3;
$zahlZwei = 3 * (2 + 2.5) * 4 - 3;
$zahlDrei = 23 /...




