Cyperfriend
Der ohne Avatar
- Registriert
- 14 Juli 2013
- Beiträge
- 1.123
Also ich steh komplett auf dem Schlauch. Ich habe ein formular über das Daten eingegeben werden können. Das sieht so aus:
[src=html5] <!-- Anfang Formular -->
<div id="set_formular">
<form action="users-insert.php" method="post">
<!-- Anfang Allgemein -->
<div style="background-color:#ffad5d;">
<label for="benutzername">Benutzername</label>
<input type="text" name="benutzername" id="benutzername">
<label for="email">E-Mail</label>
<input type="text" name="email" id="email">
<label for="password">Password</label>
<input type="password" name="password" id="password">
<label for="password2">Password (Wdh.)</label>
<input type="password" name="password2" id="password2">
<input type="submit" name="speichern" value="Speichern">
</div>
<!-- Ende Allgemein -->
</form>
</div>
<!-- Ende Formular -->[/src]
Die Eingaben landen dann in einem PHP-Skript das die Eingaben prüft und schlussendlich ein Datenbankeintrag erfolgen soll. Das sieht momentan so aus:
[src=php]<?php session_start();
// var_dump($_POST);
echo "Benutzername: ".$_Post['benutzername'];
# Diese Datei enthält Funktionen, welche für das Script zwingend benötigt werden.
require_once("../../functions.inc.php");
# Diese Datei enthält die Fehlercodes.
require_once("../../codes.php");
# Datenfankverbindung herstellen
$db_connect = db_connect();
// Prüfen, ob das Formular abgeschickt wurde.
if(isset($_POST['speichern'])){
// Prüfen, ob Benutzername, Passwort und Rang gesetzt sind.
if(empty($_POST['benutzername']) || empty($_POST['password'])) {
# Code 13 = "Es wurden nicht alle Pflichtfelder ausgefüllt."
$_SESSION['code'] = 13;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
elseif($_POST['password'] != $_POST['password2']) {
# Code 22 = "Die Passwörter sind nicht gleich."
$_SESSION['code'] = 22;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
# Prüfen, ob der Benutzername bereits angelegt wurde
$db_read = $db_connect->prepare('select * from db_benutzer where benutzername=?');
$db_read->execute([$_Post['benutzername']]);
$number = $db_read->rowCount();
# Falls ein Eintrag gefunden wurde, Vorgang abbrechen
if($number >= 1){
# Code 21 = "Diesen Benutzer gibt es bereits"
$_SESSION['code'] = 21;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
else {
$db_insert = $db_connect->prepare("Insert into db_benutzer (benutzername, password, email) VALUES (:benutzername, assword, :email)");
$db_insert->execute([
'benutzername' => $_Post['benutzername'],
'password' => $_Post['password'],
'email' => $_Post['email']
]);
# Code 10 = "Eintrag gespeichert."
$_SESSION['code'] = 10;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
}
else
{
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
$db_connect->close();
?>[/src]
Prüfungen, ob das Formular abgeschickt wurde funktioniert.
Prüfung auf Eingabe von Benutzername und Passwort funktioniert
Abgleich, ob die Passwörter gleich sind funktioniert
Das Script führt unter PHP 7.4 angeblich auch einen Datenbankeintrag durch, aber das funktioniert nicht (Es wird nichts in die Datenbank geschrieben)
Unter PHP8 Beta gibt es eine Fehlermeldung
Wenn ich "var_dump($_POST);" mache gibt es folgende Ausgabe:
(Und bitte nicht meckern wegen dem Passwort. Die Verschlüsselung baue ich auch noch ein, aber erstmal eins nach dem anderen )
[Edit] Achja: die Prüfung, ob der Benutzername bereits belegt ist funktioniert nicht. Ich habe nämlich von Hand in phpMyAdmin einen Benutzer angelegt[/Edit]
[src=html5] <!-- Anfang Formular -->
<div id="set_formular">
<form action="users-insert.php" method="post">
<!-- Anfang Allgemein -->
<div style="background-color:#ffad5d;">
<label for="benutzername">Benutzername</label>
<input type="text" name="benutzername" id="benutzername">
<label for="email">E-Mail</label>
<input type="text" name="email" id="email">
<label for="password">Password</label>
<input type="password" name="password" id="password">
<label for="password2">Password (Wdh.)</label>
<input type="password" name="password2" id="password2">
<input type="submit" name="speichern" value="Speichern">
</div>
<!-- Ende Allgemein -->
</form>
</div>
<!-- Ende Formular -->[/src]
Die Eingaben landen dann in einem PHP-Skript das die Eingaben prüft und schlussendlich ein Datenbankeintrag erfolgen soll. Das sieht momentan so aus:
[src=php]<?php session_start();
// var_dump($_POST);
echo "Benutzername: ".$_Post['benutzername'];
# Diese Datei enthält Funktionen, welche für das Script zwingend benötigt werden.
require_once("../../functions.inc.php");
# Diese Datei enthält die Fehlercodes.
require_once("../../codes.php");
# Datenfankverbindung herstellen
$db_connect = db_connect();
// Prüfen, ob das Formular abgeschickt wurde.
if(isset($_POST['speichern'])){
// Prüfen, ob Benutzername, Passwort und Rang gesetzt sind.
if(empty($_POST['benutzername']) || empty($_POST['password'])) {
# Code 13 = "Es wurden nicht alle Pflichtfelder ausgefüllt."
$_SESSION['code'] = 13;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
elseif($_POST['password'] != $_POST['password2']) {
# Code 22 = "Die Passwörter sind nicht gleich."
$_SESSION['code'] = 22;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
# Prüfen, ob der Benutzername bereits angelegt wurde
$db_read = $db_connect->prepare('select * from db_benutzer where benutzername=?');
$db_read->execute([$_Post['benutzername']]);
$number = $db_read->rowCount();
# Falls ein Eintrag gefunden wurde, Vorgang abbrechen
if($number >= 1){
# Code 21 = "Diesen Benutzer gibt es bereits"
$_SESSION['code'] = 21;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
else {
$db_insert = $db_connect->prepare("Insert into db_benutzer (benutzername, password, email) VALUES (:benutzername, assword, :email)");
$db_insert->execute([
'benutzername' => $_Post['benutzername'],
'password' => $_Post['password'],
'email' => $_Post['email']
]);
# Code 10 = "Eintrag gespeichert."
$_SESSION['code'] = 10;
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
}
else
{
header("Location: http://".$_SERVER['HTTP_HOST']."/settings/users/show.php"); exit;
}
$db_connect->close();
?>[/src]
Prüfungen, ob das Formular abgeschickt wurde funktioniert.
Prüfung auf Eingabe von Benutzername und Passwort funktioniert
Abgleich, ob die Passwörter gleich sind funktioniert
Das Script führt unter PHP 7.4 angeblich auch einen Datenbankeintrag durch, aber das funktioniert nicht (Es wird nichts in die Datenbank geschrieben)
Unter PHP8 Beta gibt es eine Fehlermeldung
Also habe ich oben kurzerhand mal ein " echo "Benutzername: ".$_Post['benutzername'];" reingeschrieben. Die Variable ist leer!?Fatal error: Uncaught PDOException: SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'benutzername' cannot be null in [...]
Wenn ich "var_dump($_POST);" mache gibt es folgende Ausgabe:
Wie kann das sein? Ich blicks überhaupt nicht mehr.array(5) { ["benutzername"]=> string(14) "Max Mustermann" ["email"]=> string(18) "max@mustermann.tld" ["password"]=> string(6) "geheim" ["password2"]=> string(6) "geheim" ["speichern"]=> string(9) "Speichern" }
(Und bitte nicht meckern wegen dem Passwort. Die Verschlüsselung baue ich auch noch ein, aber erstmal eins nach dem anderen )
[Edit] Achja: die Prüfung, ob der Benutzername bereits belegt ist funktioniert nicht. Ich habe nämlich von Hand in phpMyAdmin einen Benutzer angelegt[/Edit]
Zuletzt bearbeitet: