Einfache Serververwaltung mit PHP und MySQL: Unterschied zwischen den Versionen
| Zeile 93: | Zeile 93: | ||
</pre> | </pre> | ||
| − | + | == PHP-Skript zur Verarbeitung des Eintrags == | |
| − | + | Dateiname: '''/var/www/html/eintragen.php''' | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | == PHP-Skript | ||
| − | Dateiname: '''/var/www/html/ | ||
<pre> | <pre> | ||
<?php | <?php | ||
| + | include 'db.php'; | ||
session_start(); | session_start(); | ||
| − | $ | + | if (!isset($_SESSION["benutzername"])) { |
| − | + | header("Location: login.html"); | |
| − | + | exit; | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
} | } | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
if ($_SERVER["REQUEST_METHOD"] == "POST") { | 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 = " | + | $sql = "INSERT INTO server (rechnername, ip_adresse, betriebssystem, festplattenspeicher, ram, hauptdienst) |
| − | + | VALUES ('$rechnername', '$ip_adresse', '$betriebssystem', '$festplattenspeicher', '$ram', '$hauptdienst')"; | |
| − | if ($ | + | if ($conn->query($sql) === TRUE) { |
| − | |||
header("Location: liste.php"); | header("Location: liste.php"); | ||
| + | exit; | ||
} else { | } else { | ||
| − | echo " | + | echo "Fehler: " . $conn->error; |
} | } | ||
} | } | ||
?> | ?> | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
</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.