HTTP-Server mit PHP: Unterschied zwischen den Versionen

Aus Vokabulabor
Zur Navigation springen Zur Suche springen
Zeile 86: Zeile 86:
  <nav class="navbar navbar-expand-sm navbar-dark bg-dark">
  <nav class="navbar navbar-expand-sm navbar-dark bg-dark">
   <div class="container-fluid">
   <div class="container-fluid">
     <a class="navbar-brand" href=" #">Logo</a>
     <a class="navbar-brand" href="/demo.php?home">Logo</a>
     <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mynavbar">
     <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mynavbar">
       <span class="navbar-toggler-icon"></span>
       <span class="navbar-toggler-icon"></span>
Zeile 93: Zeile 93:
       <ul class="navbar-nav me-auto">
       <ul class="navbar-nav me-auto">
         <li class="nav-item">
         <li class="nav-item">
           <a class="nav-link" href="#">Start</a>
           <a class="nav-link" href="/demo.php?home">Start</a>
         </li>
         </li>
         <li class="nav-item">
         <li class="nav-item">
Zeile 130: Zeile 130:
     <nav class="navbar navbar-expand-sm navbar-dark bg-dark">
     <nav class="navbar navbar-expand-sm navbar-dark bg-dark">
         <div class="container-fluid">
         <div class="container-fluid">
           <a class="navbar-brand" href=" #">Logo</a>
           <a class="navbar-brand" href="/demo.php?home">Logo</a>
           <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mynavbar">
           <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mynavbar">
             <span class="navbar-toggler-icon"></span>
             <span class="navbar-toggler-icon"></span>
Zeile 137: Zeile 137:
             <ul class="navbar-nav me-auto">
             <ul class="navbar-nav me-auto">
               <li class="nav-item">
               <li class="nav-item">
                 <a class="nav-link" href="#">Start</a>
                 <a class="nav-link" href="/demo.php?home">Start</a>
               </li>
               </li>
               <li class="nav-item">
               <li class="nav-item">
Zeile 160: Zeile 160:
</html>
</html>
</pre>
</pre>
== Starten der Webanwendung ==
PHP bringt einen Webserver mit. Dieser kann in Visual Studio Code benutzt werden:
* Ganz rechts das Symbol Dreieck ("Start") mit Käferchen (Run-and-Debug) anklicken
* Oben in der Zeile "Run and Debug" ist ein Zahnrad: Einstellungen
* Es wird die Datei lauch.json angezeigt.
<pre>
  "configurations": [
        {
            "name": "Launch built-in server and debug",
            "type": "php",
            "request": "launch",
            "runtimeArgs": [
                "-S",
                "localhost:8000",
                "-t",
                "."
            ],
            "port": 9003,
            "serverReadyAction": {
                "action": "openExternally"
            }
        },
</pre>
* Wir merken uns: "localhost:8000".
* Oben in der Zeile "Run and Debug" in der Combobox "Launch build-in server" auswählen und auf den Startpfeil (Dreieck) klicken
* Im Browser in die Adresszeile eintragen: localhost:8000/demo.php
* Es erscheint unsere Homepage. Seltsamerweise steht in der Adresszeile localhost:8000/demo.php?home
* In der Datei demo.php in die Zeile 2 klicken, und zwar vor der Zeilennummer. Es erscheint ein roter Punkt: Wir haben einen Breakpoint gesetzt.
* Im Browser eintragen: <code>localhost:8000/demo.php</code>, Return
* Die 2.te Zeile im Browser wird gelb: Der Debugger hat am Breakpunkt angehalten.
* Wir können jetzt die Variablen anschauen: Rechts "Superglobals" durch Anklicken aufklappen, $_SERVER aufklappen
* Wir sehen hier alle Werte des Arrays $_SERVER. Auch den Eintrag "REQUEST_URI".
* Mit der Taste F10 führen wir genau ein Statement aus und landen in Zeile 3, noch ein F10 geht nach Zeile 4, also zu <code>header('Location: http:/demo.php?home');</code>
* Diese Anweisung sorgt für eine Weiterleitung auf die Adresse "http:/demo.php?home"
* Wir lassen das Programm mit F5 ("Run") weiterlaufen
* Ohne dass wir im Browser was gemacht haben, stoppt der Debugger wieder in Zeile 2. Wenn wir mit F10 weitergehen, landen wir diesmal in Zeile 6.
** Der Browser hat also automatisch die Adresse http:/demo.php?home' aufgerufen.
** In Zeile 6 landen wir in der Methode home() der Klasse Server.
** Diese liest die Datei home.html und gibt sie einfach aus.
** Der Browser bekommt den Inhalt der Datei home.html und zeigt sie an.
* Wir klicken im Browser in der Titelzeile den Link "Impressum" an.
* Wir landen wieder in Zeile 2.
** Mit F10 weitergehen, wir landen in Zeile 8.
** Dort wird die Datei impressum.html gelesen und ausgegeben.
** Mit F5 läuft das Programm weiter und der Browser zeigt die Impressumseite an.

Version vom 16. Oktober 2023, 20:57 Uhr

Links

Zielsetzung

Verständnis für den Ablauf der Kommunikation beim HTTP-Protokoll.

Das HTTP-Protokoll erlaubt es vielen Clients, mit einem Server Verbindung aufzunehmen und Daten auszutauschen.

Ein typischer HTTP-Client ist ein Browser: Er fordert Webseiten vom Webserver an und zeigt diese an.

Wir zeigen hier, wie ein minimaler HTTP-Server mittels PHP programmiert wird.

Das HTTP-Protokoll

Das Hypertext Transfer Protocol (HTTP) ist ein weit verbreitetes Protokoll, das in der Regel zur Übertragung von Daten im World Wide Web (WWW) verwendet wird. Es bildet die Grundlage für den Datenaustausch zwischen Webclients (z.B. Browsern wie Firefox) und Webservern. Das Prinzip des HTTP-Protokolls lässt sich in folgenden Schritten zusammenfassen:

Anforderung (Request)

Ein Client, in der Regel ein Webbrowser, sendet eine HTTP-Anforderung an einen Webserver. Diese Anforderung kann verschiedene Methoden wie GET, POST, PUT oder DELETE verwenden, um den Server über die gewünschte Aktion zu informieren.

Die Anforderung enthält immer eine URL (Universal Resource Locator): das ist die "Webadresse", in der verschieden Informationen zusammengefasst sind:

Beispiel einer URL: https://vokabulabor.hamatoma.de/index.php?title=HTTP-Server_mit_PHP&action=edit

  • https: Das SchemaProtokoll: https steht für verschlüsseltes HTML, http für unverschlüsseltes. Möglich ist auch file:
  • //vokabulabor.hamatoma.de ist die Domäne. Es gibt eine System namens Domain Name System (DNS), bei der abgefragt werden kann, wo auf der Welt diese Domäne ist und "das Internet" weiß dann, wie die Anfrage dorthin geleitet werden kann.
  • /index.php Dieser Pfad sagt dem Webserver, welche Info er bereitstellen soll.
  • ?title=HTTP-Server_mit_PHP&action=edit Das sind die Abfrage (Query) einer Anfrage. Dort werden Zusatzinformationen mitgegeben.


Verbindungsaufbau

Wenn der Client eine Anforderung sendet, baut er eine Verbindung zum Server auf. Dies kann über das TCP/IP-Protokoll erfolgen, wobei normalerweise Port 80 für unverschlüsseltes HTTP und Port 443 für verschlüsseltes HTTPS verwendet wird.

Verarbeitung der Anforderung

Der Webserver empfängt die Anforderung und verarbeitet sie entsprechend. Dies kann das Bereitstellen von Ressourcen wie HTML-Seiten, Bildern, Videos oder anderen Daten beinhalten.

Antwort (Response)

Als Antwort schickt der Webserver Daten: das ist meistens eine HTML-Seite oder eine Datei (z.B. eine CSS-Datei).

Die Antwort enthält immer eine Statuscode:

  • 200: OK Die Anfrage wurde korrekt beantwortet
  • 301: Die Antwort steht unter einer anderen URL zur Verfügung. Der Browser stellt dann automatisch die Anfrage unter dieser URL.
  • 404: Seite unbekannt: Der Server kennt die URL nicht.
  • 403: Verboten: Ohne Anmeldung ist die Seite nicht erreichbar

PHP-Programm einer Webanwendung

Wir legen einer Datei demo.php an:

<?php
$server = new Server();
if ($_SERVER['REQUEST_URI'] == '/demo.php') {
    header('Location: http:/demo.php?home');
} elseif ($_SERVER['REQUEST_URI'] === '/demo.php?home') {
    $server->home();
} elseif ($_SERVER['REQUEST_URI'] === '/demo.php?impressum') {
    $server->impressum();
} else {
    header("HTTP/1.0 404 Not Found");
}
class Server {
    public function home(){
        $page = file_get_contents('home.html');
        echo $page;
    }
    public function impressum(){
        $page = file_get_contents('impressum.html');
        echo $page;
    }
}

Wir brauchen noch eine HTML-Datei home.html:

<!DOCTYPE html>
<html lang="en">
<head>
  <title>Bootstrap 5 Example</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/css/bootstrap.min.css" rel="stylesheet">
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/js/bootstrap.bundle.min.js"></script>
</head>
<body>
 <nav class="navbar navbar-expand-sm navbar-dark bg-dark">
  <div class="container-fluid">
    <a class="navbar-brand" href="/demo.php?home">Logo</a>
    <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mynavbar">
      <span class="navbar-toggler-icon"></span>
    </button>
    <div class="collapse navbar-collapse" id="mynavbar">
      <ul class="navbar-nav me-auto">
        <li class="nav-item">
          <a class="nav-link" href="/demo.php?home">Start</a>
        </li>
        <li class="nav-item">
          <a class="nav-link" href="demo.php?impressum">Impressum</a>
        </li>
      </ul>
      <form class="d-flex">
        
        <button class="btn btn-secondary" type="button">Settings</button>
        <button class="btn btn-primary" type="button">Logout</button>
      </form>
    </div>
  </div>
</nav> 
<div class="container-fluid p-5 bg-primary text-white text-center">
  <h1>Meine erste  Bootstrapseite</h1> 
</div>
<div class="container mt-5">
    <p>Hier geht es zum <a href="demo.php?login">Login</a></p>
</div>
</body>
</html>

Wir brauchen noch eine HTML-Datei impressum.html:

<!DOCTYPE html>
<html lang="en">
<head>
  <title>Bootstrap 5 Example</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/css/bootstrap.min.css" rel="stylesheet">
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/js/bootstrap.bundle.min.js"></script>
</head>
<body>
    <nav class="navbar navbar-expand-sm navbar-dark bg-dark">
        <div class="container-fluid">
          <a class="navbar-brand" href="/demo.php?home">Logo</a>
          <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mynavbar">
            <span class="navbar-toggler-icon"></span>
          </button>
          <div class="collapse navbar-collapse" id="mynavbar">
            <ul class="navbar-nav me-auto">
              <li class="nav-item">
                <a class="nav-link" href="/demo.php?home">Start</a>
              </li>
              <li class="nav-item">
                <a class="nav-link" href="demo.php?impressum">Impressum</a>
              </li>
            </ul>
            <form class="d-flex">
              
              <button class="btn btn-secondary" type="button">Settings</button>
              <button class="btn btn-primary" type="button">Logout</button>
            </form>
          </div>
        </div>
      </nav> 
      <div class="container-fluid p-5 bg-primary text-white text-center">
  <h1>Impressum</h1> 
</div>
<div class="container mt-5 text-center">
    <p>Verantwortlich ist der Autor.</p>
</div>
</body>
</html>

Starten der Webanwendung

PHP bringt einen Webserver mit. Dieser kann in Visual Studio Code benutzt werden:

  • Ganz rechts das Symbol Dreieck ("Start") mit Käferchen (Run-and-Debug) anklicken
  • Oben in der Zeile "Run and Debug" ist ein Zahnrad: Einstellungen
  • Es wird die Datei lauch.json angezeigt.
   "configurations": [
        {
            "name": "Launch built-in server and debug",
            "type": "php",
            "request": "launch",
            "runtimeArgs": [
                "-S",
                "localhost:8000",
                "-t",
                "."
            ],
            "port": 9003,
            "serverReadyAction": {
                "action": "openExternally"
            }
        },
  • Wir merken uns: "localhost:8000".
  • Oben in der Zeile "Run and Debug" in der Combobox "Launch build-in server" auswählen und auf den Startpfeil (Dreieck) klicken
  • Im Browser in die Adresszeile eintragen: localhost:8000/demo.php
  • Es erscheint unsere Homepage. Seltsamerweise steht in der Adresszeile localhost:8000/demo.php?home
  • In der Datei demo.php in die Zeile 2 klicken, und zwar vor der Zeilennummer. Es erscheint ein roter Punkt: Wir haben einen Breakpoint gesetzt.
  • Im Browser eintragen: localhost:8000/demo.php, Return
  • Die 2.te Zeile im Browser wird gelb: Der Debugger hat am Breakpunkt angehalten.
  • Wir können jetzt die Variablen anschauen: Rechts "Superglobals" durch Anklicken aufklappen, $_SERVER aufklappen
  • Wir sehen hier alle Werte des Arrays $_SERVER. Auch den Eintrag "REQUEST_URI".
  • Mit der Taste F10 führen wir genau ein Statement aus und landen in Zeile 3, noch ein F10 geht nach Zeile 4, also zu header('Location: http:/demo.php?home');
  • Diese Anweisung sorgt für eine Weiterleitung auf die Adresse "http:/demo.php?home"
  • Wir lassen das Programm mit F5 ("Run") weiterlaufen
  • Ohne dass wir im Browser was gemacht haben, stoppt der Debugger wieder in Zeile 2. Wenn wir mit F10 weitergehen, landen wir diesmal in Zeile 6.
    • Der Browser hat also automatisch die Adresse http:/demo.php?home' aufgerufen.
    • In Zeile 6 landen wir in der Methode home() der Klasse Server.
    • Diese liest die Datei home.html und gibt sie einfach aus.
    • Der Browser bekommt den Inhalt der Datei home.html und zeigt sie an.
  • Wir klicken im Browser in der Titelzeile den Link "Impressum" an.
  • Wir landen wieder in Zeile 2.
    • Mit F10 weitergehen, wir landen in Zeile 8.
    • Dort wird die Datei impressum.html gelesen und ausgegeben.
    • Mit F5 läuft das Programm weiter und der Browser zeigt die Impressumseite an.