• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

$_Post-Variable wird übergeben und doch nicht übergeben

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, :password, :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
Fatal error: Uncaught PDOException: SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'benutzername' cannot be null in [...]
Also habe ich oben kurzerhand mal ein " echo "Benutzername: ".$_Post['benutzername'];" reingeschrieben. Die Variable ist leer!?

Wenn ich "var_dump($_POST);" mache gibt es folgende Ausgabe:
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" }
Wie kann das sein? Ich blicks überhaupt nicht mehr.

(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:

theSplit

1998
Veteran Barkeeper

Registriert
3 Aug. 2014
Beiträge
28.560
Moin!

Du kannst nicht [kw]$_Post[/kw] nehmen, die Variable heißt korrekt [kw]$_POST[/kw].
Das siehst du auch wenn du ein [kw]var_dump($_Post)[/kw] machst, die Ausgabe des Aufrufs ist [kw]NULL[/kw].

Das bezieht sich zum Beispiel auf den Insert in Zeile: 29 und die Zeilen 40 bis 42.

Deshalb bekommst du auch im Excecute den Fehler dass der Parameter benutzername' NULL ist.
 

one

Querulant

Registriert
21 Juli 2013
Beiträge
5.838
Ort
ja
Zeile 29

$db_read->execute([$_Post['benutzername']]);

Ein ] zuviel.
 

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
  • Thread Starter Thread Starter
  • #6
Danke. Da sieht man, welcher Teil damals noch mit Dreamweaver erstellt wurde. Da wurde das scheinbar automatisch groß geschrieben. Ich hatte jetzt gar nicht darauf geachtet, bzw. wusste auch gar nicht, dass die Befehle Case-Sensitive sind.
 

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
  • Thread Starter Thread Starter
  • #8
Stimmt, aber irgendwie hatte ich $_POST nicht als Variable im Kopf, sondern als Befehl, obwohls ja eigentlich klar ist mit dem $ vornedran.
 
Oben