Einfache Serververwaltung mit PHP und MySQL: Unterschied zwischen den Versionen
| Zeile 1: | Zeile 1: | ||
| + | = Projekt: Einfache Serververwaltung mit PHP und MySQL = | ||
== Ziel des Projekts == | == Ziel des Projekts == | ||
| Zeile 45: | Zeile 46: | ||
Tabelle für die Serverdaten anlegen: | Tabelle für die Serverdaten anlegen: | ||
| − | <pre> | + | * <pre> |
create table server ( | create table server ( | ||
id int auto_increment primary key, | id int auto_increment primary key, | ||
| Zeile 58: | Zeile 59: | ||
Tabelle für die Benutzerverwaltung anlegen: | Tabelle für die Benutzerverwaltung anlegen: | ||
| − | <pre> | + | * <pre> |
create table benutzer ( | create table benutzer ( | ||
id int auto_increment primary key, | id int auto_increment primary key, | ||
| Zeile 69: | Zeile 70: | ||
== Benutzer anlegen == | == Benutzer anlegen == | ||
Damit sich Benutzer anmelden können, müssen sie in der Datenbank registriert werden: | Damit sich Benutzer anmelden können, müssen sie in der Datenbank registriert werden: | ||
| − | * '''insert into benutzer (benutzername, passwort, rolle) values ('admin', password(' | + | * '''insert into benutzer (benutzername, passwort, rolle) values ('admin', password('adminpass'), 'admin');''' |
| − | * '''insert into benutzer (benutzername, passwort, rolle) values (' | + | * '''insert into benutzer (benutzername, passwort, rolle) values ('user', password('userpass'), 'user');''' |
== Speicherort der Skripte == | == Speicherort der Skripte == | ||
| Zeile 92: | Zeile 93: | ||
</pre> | </pre> | ||
| − | == PHP-Skript | + | == Login-Seite == |
| − | Dateiname: '''/var/www/html/ | + | Dateiname: '''/var/www/html/login.html''' |
| + | |||
| + | <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 | ||
| − | |||
session_start(); | session_start(); | ||
| − | + | $servername = "localhost"; | |
| − | + | $username = "root"; | |
| − | + | $password = "passwort"; | |
| + | $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"]; |
| − | $ | + | $passwort = $_POST["passwort"]; |
| − | |||
| − | |||
| − | |||
| − | |||
| − | $sql = " | + | $sql = "SELECT * FROM benutzer WHERE benutzername='$benutzername' AND passwort=password('$passwort')"; |
| − | + | $result = $conn->query($sql); | |
| − | if ($ | + | if ($result->num_rows == 1) { |
| + | $_SESSION["benutzername"] = $benutzername; | ||
header("Location: liste.php"); | header("Location: liste.php"); | ||
exit; | exit; | ||
} else { | } else { | ||
| − | echo " | + | echo "Falsche Anmeldedaten."; |
| + | } | ||
| + | } | ||
| + | ?> | ||
| + | </pre> | ||
| + | |||
| + | == Serverliste anzeigen == | ||
| + | Dateiname: '''/var/www/html/liste.php''' | ||
| + | |||
| + | <pre> | ||
| + | <?php | ||
| + | include 'db.php'; | ||
| + | |||
| + | $result = $conn->query("SELECT * FROM server"); | ||
| + | |||
| + | if ($result->num_rows > 0) { | ||
| + | echo "<table border='1'> | ||
| + | <tr><th>ID</th><th>Rechnername</th><th>IP-Adresse</th><th>Betriebssystem</th><th>Festplatte (GB)</th><th>RAM (GB)</th><th>Hauptdienst</th></tr>"; | ||
| + | while($row = $result->fetch_assoc()) { | ||
| + | echo "<tr><td>" . $row["id"] . "</td><td>" . $row["rechnername"] . "</td><td>" . $row["ip_adresse"] . "</td><td>" . $row["betriebssystem"] . "</td><td>" . $row["festplattenspeicher"] . "</td><td>" . $row["ram"] . "</td><td>" . $row["hauptdienst"] . "</td></tr>"; | ||
} | } | ||
| + | echo "</table>"; | ||
| + | } else { | ||
| + | echo "Keine Server gefunden."; | ||
} | } | ||
?> | ?> | ||
Version vom 15. März 2025, 14:23 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>
Login-Seite
Dateiname: /var/www/html/login.html
<!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>
PHP-Skript für die Datenbankverbindung
Dateiname: /var/www/html/db.php
<?php
session_start();
$servername = "localhost";
$username = "root";
$password = "passwort";
$dbname = "serververwaltung";
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
die("Verbindung fehlgeschlagen: " . $conn->connect_error);
}
?>
Benutzeranmeldung
Dateiname: /var/www/html/login.php
<?php
include 'db.php';
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$benutzername = $_POST["benutzername"];
$passwort = $_POST["passwort"];
$sql = "SELECT * FROM benutzer WHERE benutzername='$benutzername' AND passwort=password('$passwort')";
$result = $conn->query($sql);
if ($result->num_rows == 1) {
$_SESSION["benutzername"] = $benutzername;
header("Location: liste.php");
exit;
} else {
echo "Falsche Anmeldedaten.";
}
}
?>
Serverliste anzeigen
Dateiname: /var/www/html/liste.php
<?php
include 'db.php';
$result = $conn->query("SELECT * FROM server");
if ($result->num_rows > 0) {
echo "<table border='1'>
<tr><th>ID</th><th>Rechnername</th><th>IP-Adresse</th><th>Betriebssystem</th><th>Festplatte (GB)</th><th>RAM (GB)</th><th>Hauptdienst</th></tr>";
while($row = $result->fetch_assoc()) {
echo "<tr><td>" . $row["id"] . "</td><td>" . $row["rechnername"] . "</td><td>" . $row["ip_adresse"] . "</td><td>" . $row["betriebssystem"] . "</td><td>" . $row["festplattenspeicher"] . "</td><td>" . $row["ram"] . "</td><td>" . $row["hauptdienst"] . "</td></tr>";
}
echo "</table>";
} else {
echo "Keine Server gefunden.";
}
?>
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.