PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Optimierung von Login Session mit PHP & MySQL
Beitrag
<blockquote data-quote="ddjjmm" data-source="post: 1779324" data-attributes="member: 472728"><p>Hallo zusammen <img src="/styles/default/xenforo/smilies/zwinker.gif" class="smilie" loading="lazy" alt=";)" title="Wink ;)" data-shortname=";)" /></p><p></p><p>ich habe mich durch diverse Tutorials gearbeitet und letztendlich für meine Seite ein Login Session Skript gebaut mit Anbindung an die MySQL Datenbank.</p><p></p><p>Es funktioniert auch einwandfrei, allerdings bin ich mir nicht ganz sicher ob es so elegant umgesetzt ist bzw. ob man es optmimieren kann, daher wollte ich es hier kurz vorstellen und Rückmeldungen & Tipps einholen:</p><p></p><p>In der <strong>header.php</strong> und damit auf jeder Seite ist folgendes sofort zum Abfragen eines gültigen Logins zu Beginn:</p><p>[PHP]<?php include ("logincheck.php"); ?> [/PHP]Die Datei <strong>logincheck.php</strong> sieht wie folgt aus:</p><p>[PHP]<?php </p><p>session_start(); </p><p>include_once("config.inc.php");</p><p>if (!isset ($_SESSION["user_id"])) </p><p>{ </p><p> header ("Location: index.php"); // Redirect wenn ohne Login Session</p><p>} </p><p>?> [/PHP]In der <strong>config.inc.php</strong> habe ich den Verbindungsaufbau zur Datenbank realisiert:</p><p>[PHP]<?php </p><p></p><p>// Datenbank Zugangsdaten</p><p></p><p>// Datenbankserver: Servername oder IP-Adresse</p><p>$dbserver = "localhost";</p><p></p><p>// Datenbank Benutzer</p><p>$dbuser = "dbusername";</p><p></p><p>// Datenbank Passwort</p><p>$dbpw = "dbpasswort";</p><p></p><p>// Datenbank Name</p><p>$dbname = "dbname";</p><p></p><p>// Datenbank Tabellen</p><p>$dbtable_user = "benutzerdaten";</p><p>$dbtable_bestand = "bestand";</p><p></p><p>// Verbindung aufbauen</p><p>@$db = new mysqli($dbserver, $dbuser, $dbpw, $dbname) or die("Keine Verbindung zur Datenbank!");</p><p></p><p>// Pruefen ob die Datenbankverbindung hergestellt werden konnte</p><p>if (mysqli_connect_errno() == 0)</p><p>{</p><p> /*</p><p> * Hier wird Code ausgefuehrt, wenn die Datenbankverbindung</p><p> * fehlerfrei hergestellt werden konnte.</p><p> */</p><p>}</p><p>else</p><p>{</p><p> // Es konnte keine Datenbankverbindung aufgebaut werden</p><p> echo 'Die Datenbank konnte nicht erreicht werden. Folgender Fehler trat auf: <span class="hinweis">' .mysqli_connect_errno(). ' : ' .mysqli_connect_error(). '</span>';</p><p>}</p><p>[/PHP]Und sollte der User nicht bereits eingeloggt sein, wird er auf die Loginseite umgeleitet und die Formulardaten an folgende <strong>login.php</strong> schickt:</p><p>[PHP]<?php </p><p>// Session starten</p><p>session_start();</p><p></p><p>include_once("config.inc.php");</p><p></p><p>$sql = "SELECT ". "Id, Nickname, Nachname, Vorname "."FROM "."benutzerdaten "."WHERE "."(Nickname like '".$_REQUEST["name"]."') AND "."(Kennwort = '".md5 ($_REQUEST["pwd"])."')"; </p><p></p><p>$result = $db->query($sql);</p><p></p><p>if (mysqli_num_rows($result) > 0) </p><p>{ </p><p> // Benutzerdaten in ein Array auslesen. </p><p> $data = mysqli_fetch_array ($result); </p><p></p><p> // Sessionvariablen erstellen und registrieren - Sachen die übernommen werden sollen</p><p> $_SESSION["user_id"] = $data["Id"]; </p><p> $_SESSION["user_nickname"] = $data["Nickname"]; </p><p> $_SESSION["user_nachname"] = $data["Nachname"]; </p><p> $_SESSION["user_vorname"] = $data["Vorname"]; </p><p></p><p> header ("Location: start.php"); // Weiterleitung bei korrektem Login</p><p>} </p><p>else </p><p>{ </p><p> header ("Location: index.php?fehler=1"); </p><p>} </p><p>?> [/PHP]Gibt es soweit für meine Vorgehensweise Ratschläge? Mache ich etwas falsch oder gar unnötig kompliziert? Später sollen weitere Datenbankabfrage und auch Updates durch den Nutzer stattfinden.</p><p></p><p>Vielen Dank im Voraus <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" class="smilie smilie--sprite smilie--sprite1" alt=":)" title="Smile :)" loading="lazy" data-shortname=":)" /></p></blockquote><p></p>
[QUOTE="ddjjmm, post: 1779324, member: 472728"] Hallo zusammen ;) ich habe mich durch diverse Tutorials gearbeitet und letztendlich für meine Seite ein Login Session Skript gebaut mit Anbindung an die MySQL Datenbank. Es funktioniert auch einwandfrei, allerdings bin ich mir nicht ganz sicher ob es so elegant umgesetzt ist bzw. ob man es optmimieren kann, daher wollte ich es hier kurz vorstellen und Rückmeldungen & Tipps einholen: In der [B]header.php[/B] und damit auf jeder Seite ist folgendes sofort zum Abfragen eines gültigen Logins zu Beginn: [PHP]<?php include ("logincheck.php"); ?> [/PHP]Die Datei [B]logincheck.php[/B] sieht wie folgt aus: [PHP]<?php session_start(); include_once("config.inc.php"); if (!isset ($_SESSION["user_id"])) { header ("Location: index.php"); // Redirect wenn ohne Login Session } ?> [/PHP]In der [B]config.inc.php[/B] habe ich den Verbindungsaufbau zur Datenbank realisiert: [PHP]<?php // Datenbank Zugangsdaten // Datenbankserver: Servername oder IP-Adresse $dbserver = "localhost"; // Datenbank Benutzer $dbuser = "dbusername"; // Datenbank Passwort $dbpw = "dbpasswort"; // Datenbank Name $dbname = "dbname"; // Datenbank Tabellen $dbtable_user = "benutzerdaten"; $dbtable_bestand = "bestand"; // Verbindung aufbauen @$db = new mysqli($dbserver, $dbuser, $dbpw, $dbname) or die("Keine Verbindung zur Datenbank!"); // Pruefen ob die Datenbankverbindung hergestellt werden konnte if (mysqli_connect_errno() == 0) { /* * Hier wird Code ausgefuehrt, wenn die Datenbankverbindung * fehlerfrei hergestellt werden konnte. */ } else { // Es konnte keine Datenbankverbindung aufgebaut werden echo 'Die Datenbank konnte nicht erreicht werden. Folgender Fehler trat auf: <span class="hinweis">' .mysqli_connect_errno(). ' : ' .mysqli_connect_error(). '</span>'; } [/PHP]Und sollte der User nicht bereits eingeloggt sein, wird er auf die Loginseite umgeleitet und die Formulardaten an folgende [B]login.php[/B] schickt: [PHP]<?php // Session starten session_start(); include_once("config.inc.php"); $sql = "SELECT ". "Id, Nickname, Nachname, Vorname "."FROM "."benutzerdaten "."WHERE "."(Nickname like '".$_REQUEST["name"]."') AND "."(Kennwort = '".md5 ($_REQUEST["pwd"])."')"; $result = $db->query($sql); if (mysqli_num_rows($result) > 0) { // Benutzerdaten in ein Array auslesen. $data = mysqli_fetch_array ($result); // Sessionvariablen erstellen und registrieren - Sachen die übernommen werden sollen $_SESSION["user_id"] = $data["Id"]; $_SESSION["user_nickname"] = $data["Nickname"]; $_SESSION["user_nachname"] = $data["Nachname"]; $_SESSION["user_vorname"] = $data["Vorname"]; header ("Location: start.php"); // Weiterleitung bei korrektem Login } else { header ("Location: index.php?fehler=1"); } ?> [/PHP]Gibt es soweit für meine Vorgehensweise Ratschläge? Mache ich etwas falsch oder gar unnötig kompliziert? Später sollen weitere Datenbankabfrage und auch Updates durch den Nutzer stattfinden. Vielen Dank im Voraus :) [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 5, ▼ = 2 und ■ = 7, was ist ▲ × ▼ + ■?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Optimierung von Login Session mit PHP & MySQL
Oben