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 /...