Einfache Serververwaltung mit PHP und MySQL: Unterschied zwischen den Versionen

Aus Xinux Wiki
Zur Navigation springen Zur Suche springen
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: **/var/www/html/db.php**
+
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: **/var/www/html/index.html**
+
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: **/var/www/html/eintragen.php**
+
Dateiname: '''/var/www/html/eintragen.php'''
  
 
<pre>
 
<pre>
Zeile 128: Zeile 132:
  
 
== Anzeige der Serverliste ==
 
== Anzeige der Serverliste ==
Dateiname: **/var/www/html/liste.php**
+
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: **/var/www/html/login.php**
+
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.