Einfache Serververwaltung mit PHP und MySQL: Unterschied zwischen den Versionen
| Zeile 21: | Zeile 21: | ||
Pakete aktualisieren: | Pakete aktualisieren: | ||
| − | * apt update && apt upgrade -y | + | * '''apt update && apt upgrade -y''' |
Benötigte Software installieren: | Benötigte Software installieren: | ||
| − | * apt install apache2 mariadb-server php php-mysql libapache2-mod-php -y | + | * '''apt install apache2 mariadb-server php php-mysql libapache2-mod-php -y''' |
Apache und MariaDB starten und aktivieren: | Apache und MariaDB starten und aktivieren: | ||
| − | * systemctl enable --now apache2 mariadb | + | * '''systemctl enable --now apache2 mariadb''' |
Datenbank absichern: | Datenbank absichern: | ||
| − | * mysql_secure_installation | + | * '''mysql_secure_installation''' |
(Fragen zur Absicherung beantworten und Root-Passwort setzen) | (Fragen zur Absicherung beantworten und Root-Passwort setzen) | ||
== Anmeldung an der Datenbank == | == Anmeldung an der Datenbank == | ||
| − | * mysql -u root | + | * '''mysql -u root''' |
== Einrichtung der Datenbank == | == Einrichtung der Datenbank == | ||
| Zeile 40: | Zeile 40: | ||
Datenbank erstellen: | Datenbank erstellen: | ||
| − | * create database serververwaltung; | + | * '''create database serververwaltung;''' |
Zur neuen Datenbank wechseln: | Zur neuen Datenbank wechseln: | ||
| − | * use serververwaltung; | + | * '''use serververwaltung;''' |
Tabelle für die Serverdaten anlegen: | Tabelle für die Serverdaten anlegen: | ||
| − | * create table server ( | + | * <pre> |
| + | create table server ( | ||
id int auto_increment primary key, | id int auto_increment primary key, | ||
rechnername varchar(50) not null, | rechnername varchar(50) not null, | ||
| Zeile 55: | Zeile 56: | ||
hauptdienst varchar(50) not null | hauptdienst varchar(50) not null | ||
); | ); | ||
| + | </pre> | ||
Tabelle für die Benutzerverwaltung anlegen: | Tabelle für die Benutzerverwaltung anlegen: | ||
| − | * create table benutzer ( | + | * <pre> |
| + | create table benutzer ( | ||
id int auto_increment primary key, | id int auto_increment primary key, | ||
benutzername varchar(50) not null unique, | benutzername varchar(50) not null unique, | ||
| Zeile 63: | Zeile 66: | ||
rolle enum('admin', 'user') not null | rolle enum('admin', 'user') not null | ||
); | ); | ||
| + | </pre> | ||
== Speicherort der Skripte == | == Speicherort der Skripte == | ||
| − | ;Die Skripte werden im Verzeichnis /var/www/html abgelegt | + | ; Die Skripte werden im Verzeichnis '''/var/www/html''' abgelegt. |
== PHP-Skript für die Datenbankverbindung == | == PHP-Skript für die Datenbankverbindung == | ||
| − | Dateiname: | + | Dateiname: '''/var/www/html/db.php''' |
<pre> | <pre> | ||
| Zeile 86: | Zeile 90: | ||
== Einstiegsseite: Formular für das Eintragen neuer Server == | == Einstiegsseite: Formular für das Eintragen neuer Server == | ||
| − | Dateiname: | + | Dateiname: '''/var/www/html/index.html''' |
<pre> | <pre> | ||
| Zeile 101: | Zeile 105: | ||
== PHP-Skript zur Verarbeitung des Formulars == | == PHP-Skript zur Verarbeitung des Formulars == | ||
| − | Dateiname: | + | Dateiname: '''/var/www/html/eintragen.php''' |
<pre> | <pre> | ||
| Zeile 128: | Zeile 132: | ||
== Anzeige der Serverliste == | == Anzeige der Serverliste == | ||
| − | Dateiname: | + | Dateiname: '''/var/www/html/liste.php''' |
<pre> | <pre> | ||
| Zeile 151: | Zeile 155: | ||
== Benutzerverwaltung == | == Benutzerverwaltung == | ||
Registrierung von Benutzern in der Datenbank: | Registrierung von Benutzern in der Datenbank: | ||
| − | * insert into benutzer (benutzername, passwort, rolle) values ('admin', password('adminpass'), 'admin'); | + | * '''insert into benutzer (benutzername, passwort, rolle) values ('admin', password('adminpass'), 'admin');''' |
| − | * insert into benutzer (benutzername, passwort, rolle) values ('user', password('userpass'), 'user'); | + | * '''insert into benutzer (benutzername, passwort, rolle) values ('user', password('userpass'), 'user');''' |
| − | Dateiname: | + | Dateiname: '''/var/www/html/login.php''' |
<pre> | <pre> | ||
Version vom 15. März 2025, 13:38 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
);
Speicherort der Skripte
- Die Skripte werden im Verzeichnis /var/www/html abgelegt.
PHP-Skript für die Datenbankverbindung
Dateiname: /var/www/html/db.php
<?php
$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);
}
?>
Einstiegsseite: Formular für das Eintragen neuer Server
Dateiname: /var/www/html/index.html
<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>
PHP-Skript zur Verarbeitung des Formulars
Dateiname: /var/www/html/eintragen.php
<?php
include 'db.php';
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) {
echo "Server erfolgreich eingetragen.";
} else {
echo "Fehler: " . $conn->error;
}
}
?>
Anzeige der Serverliste
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.";
}
?>
Benutzerverwaltung
Registrierung von Benutzern in der Datenbank:
- insert into benutzer (benutzername, passwort, rolle) values ('admin', password('adminpass'), 'admin');
- insert into benutzer (benutzername, passwort, rolle) values ('user', password('userpass'), 'user');
Dateiname: /var/www/html/login.php
<?php
session_start();
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;
echo "Erfolgreich eingeloggt.";
} else {
echo "Falsche Anmeldedaten.";
}
}
?>
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.