Einfache Serververwaltung mit PHP und MySQL: Unterschied zwischen den Versionen

Aus Xinux Wiki
Zur Navigation springen Zur Suche springen
Zeile 93: Zeile 93:
 
</pre>
 
</pre>
  
== Login-Seite ==
+
== PHP-Skript zur Verarbeitung des Eintrags ==
Dateiname: '''/var/www/html/login.html'''
+
Dateiname: '''/var/www/html/eintragen.php'''
 
 
<pre>
 
<!DOCTYPE html>
 
<html>
 
<head>
 
    <title>Login</title>
 
</head>
 
<body>
 
    <h2>Login</h2>
 
    <form method="post" action="login.php">
 
        Benutzername: <input type="text" name="benutzername" required><br>
 
        Passwort: <input type="password" name="passwort" required><br>
 
        <input type="submit" value="Anmelden">
 
    </form>
 
</body>
 
</html>
 
</pre>
 
 
 
== PHP-Skript für die Datenbankverbindung ==
 
Dateiname: '''/var/www/html/db.php'''
 
  
 
<pre>
 
<pre>
 
<?php
 
<?php
 +
include 'db.php';
 
session_start();
 
session_start();
$servername = "localhost";
+
if (!isset($_SESSION["benutzername"])) {
$username = "root";
+
     header("Location: login.html");
$password = "passwort";
+
    exit;
$dbname = "serververwaltung";
 
 
 
$conn = new mysqli($servername, $username, $password, $dbname);
 
 
 
if ($conn->connect_error) {
 
     die("Verbindung fehlgeschlagen: " . $conn->connect_error);
 
 
}
 
}
?>
 
</pre>
 
 
== Benutzeranmeldung ==
 
Dateiname: '''/var/www/html/login.php'''
 
 
<pre>
 
<?php
 
include 'db.php';
 
  
 
if ($_SERVER["REQUEST_METHOD"] == "POST") {
 
if ($_SERVER["REQUEST_METHOD"] == "POST") {
     $benutzername = $_POST["benutzername"];
+
     $rechnername = $_POST["rechnername"];
     $passwort = $_POST["passwort"];
+
     $ip_adresse = $_POST["ip_adresse"];
 +
    $betriebssystem = $_POST["betriebssystem"];
 +
    $festplattenspeicher = $_POST["festplattenspeicher"];
 +
    $ram = $_POST["ram"];
 +
    $hauptdienst = $_POST["hauptdienst"];
  
     $sql = "SELECT * FROM benutzer WHERE benutzername='$benutzername' AND passwort=password('$passwort')";
+
     $sql = "INSERT INTO server (rechnername, ip_adresse, betriebssystem, festplattenspeicher, ram, hauptdienst)
    $result = $conn->query($sql);
+
            VALUES ('$rechnername', '$ip_adresse', '$betriebssystem', '$festplattenspeicher', '$ram', '$hauptdienst')";
  
     if ($result->num_rows == 1) {
+
     if ($conn->query($sql) === TRUE) {
        $_SESSION["benutzername"] = $benutzername;
 
 
         header("Location: liste.php");
 
         header("Location: liste.php");
 +
        exit;
 
     } else {
 
     } else {
         echo "Falsche Anmeldedaten.";
+
         echo "Fehler: " . $conn->error;
 
     }
 
     }
 
}
 
}
 
?>
 
?>
</pre>
 
 
== Formular für das Eintragen neuer Server ==
 
Dateiname: '''/var/www/html/eintragen.html'''
 
 
<pre>
 
<?php
 
session_start();
 
if (!isset($_SESSION["benutzername"])) {
 
    header("Location: login.html");
 
    exit;
 
}
 
?>
 
<form method="post" action="eintragen.php">
 
    Rechnername: <input type="text" name="rechnername" required><br>
 
    IP-Adresse: <input type="text" name="ip_adresse" required><br>
 
    Betriebssystem: <input type="text" name="betriebssystem" required><br>
 
    Festplattenspeicher (GB): <input type="number" name="festplattenspeicher" required><br>
 
    RAM (GB): <input type="number" name="ram" required><br>
 
    Hauptdienst: <input type="text" name="hauptdienst" required><br>
 
    <input type="submit" value="Speichern">
 
</form>
 
 
</pre>
 
</pre>
  

Version vom 15. März 2025, 14:17 Uhr

Projekt: Einfache Serververwaltung mit PHP und MySQL

Ziel des Projekts

Dieses Projekt zeigt, wie eine einfache Serververwaltungs-Webseite aufgebaut wird. Dabei lernen die Teilnehmer die grundlegende Interaktion zwischen PHP, MySQL und einer Web-Oberfläche.

Die Webseite soll folgende Daten verwalten:

  • Rechnername
  • IP-Adresse mit Netzmaske
  • Betriebssystem
  • Festplattenspeicher
  • RAM
  • Hauptdienst

Zusätzlich wird eine Benutzerverwaltung integriert:

  • Bestimmte Benutzer dürfen Daten eintragen und ändern
  • Andere Benutzer dürfen nur Daten lesen
  • Am Ende wird die Webseite mit HTTPS gesichert

Installation der benötigten Pakete

Zuerst müssen die notwendigen Pakete installiert werden:

Pakete aktualisieren:

  • apt update && apt upgrade -y

Benötigte Software installieren:

  • apt install apache2 mariadb-server php php-mysql libapache2-mod-php -y

Apache und MariaDB starten und aktivieren:

  • systemctl enable --now apache2 mariadb

Datenbank absichern:

  • mysql_secure_installation
 (Fragen zur Absicherung beantworten und Root-Passwort setzen)

Anmeldung an der Datenbank

  • mysql -u root

Einrichtung der Datenbank

Nun wird eine MySQL-Datenbank eingerichtet, um die Serverinformationen zu speichern.

Datenbank erstellen:

  • create database serververwaltung;

Zur neuen Datenbank wechseln:

  • use serververwaltung;

Tabelle für die Serverdaten anlegen:

create table server (

 id int auto_increment primary key,
 rechnername varchar(50) not null,
 ip_adresse varchar(50) not null,
 betriebssystem varchar(50) not null,
 festplattenspeicher int not null,
 ram int not null,
 hauptdienst varchar(50) not null

);

Tabelle für die Benutzerverwaltung anlegen:

create table benutzer (

 id int auto_increment primary key,
 benutzername varchar(50) not null unique,
 passwort varchar(255) not null,
 rolle enum('admin', 'user') not null

);

Benutzer anlegen

Damit sich Benutzer anmelden können, müssen sie in der Datenbank registriert werden:

  • insert into benutzer (benutzername, passwort, rolle) values ('admin', password('adminpass'), 'admin');
  • insert into benutzer (benutzername, passwort, rolle) values ('user', password('userpass'), 'user');

Speicherort der Skripte

Die Skripte werden im Verzeichnis /var/www/html abgelegt.

Einstiegsseite

Dateiname: /var/www/html/index.html

<!DOCTYPE html>
<html>
<head>
    <title>Serververwaltung</title>
</head>
<body>
    <h2>Willkommen zur Serververwaltung</h2>
    <p><a href="liste.php">Serverliste anzeigen</a></p>
    <p><a href="login.html">Anmelden</a></p>
</body>
</html>

PHP-Skript zur Verarbeitung des Eintrags

Dateiname: /var/www/html/eintragen.php

<?php
include 'db.php';
session_start();
if (!isset($_SESSION["benutzername"])) {
    header("Location: login.html");
    exit;
}

if ($_SERVER["REQUEST_METHOD"] == "POST") {
    $rechnername = $_POST["rechnername"];
    $ip_adresse = $_POST["ip_adresse"];
    $betriebssystem = $_POST["betriebssystem"];
    $festplattenspeicher = $_POST["festplattenspeicher"];
    $ram = $_POST["ram"];
    $hauptdienst = $_POST["hauptdienst"];

    $sql = "INSERT INTO server (rechnername, ip_adresse, betriebssystem, festplattenspeicher, ram, hauptdienst)
            VALUES ('$rechnername', '$ip_adresse', '$betriebssystem', '$festplattenspeicher', '$ram', '$hauptdienst')";

    if ($conn->query($sql) === TRUE) {
        header("Location: liste.php");
        exit;
    } else {
        echo "Fehler: " . $conn->error;
    }
}
?>

Verschlüsselung mit HTTPS

Die gesamte Seite wird auf HTTPS umgestellt, um die Sicherheit zu erhöhen.

Fazit

Dieses Projekt zeigt, wie eine dynamische Webanwendung für die Serververwaltung entsteht.